回答編集履歴

1

追記

2017/12/01 08:06

投稿

yambejp
yambejp

スコア114814

test CHANGED
@@ -63,3 +63,103 @@
63
63
 
64
64
 
65
65
  ```
66
+
67
+
68
+
69
+ # ajaxを使ったサンプル
70
+
71
+ 仮に答えがq1=2,q2=1だとしたら「kotae_2_1.html」というページをつくって
72
+
73
+ 応募ページのリンクを書いておきます
74
+
75
+
76
+
77
+ - kotae_2_1.html
78
+
79
+ ```HTML
80
+
81
+ <a href="http://exsample.com">応募</a>
82
+
83
+ ```
84
+
85
+
86
+
87
+ それ以外のページ(例えばkotae_1_1とかkotae_1_2とか・・・)は
88
+
89
+ 作っても作らなくても問題ありません。
90
+
91
+ その上で、以下で質問をします。(そのままコピペで動くサンプル)
92
+
93
+
94
+
95
+ ```javascript
96
+
97
+ <script>
98
+
99
+ function ansercheck() {
100
+
101
+ var q1=document.querySelector('[name=q1]:checked');
102
+
103
+ var q2=document.querySelector('[name=q2]:checked');
104
+
105
+ if(q1==null || q2==null){
106
+
107
+ alert('未入力');
108
+
109
+ } else {
110
+
111
+ var xhr = new XMLHttpRequest();
112
+
113
+ xhr.open('get', 'kotae_'+q1.value+'_'+q2.value+'.html');
114
+
115
+ xhr.onload = function() {
116
+
117
+ var str="";
118
+
119
+ if(this.status==200){
120
+
121
+ str=this.response;
122
+
123
+ }else{
124
+
125
+ str="不正解";
126
+
127
+ }
128
+
129
+ console.log(str);
130
+
131
+ document.querySelector('#kekka').innerHTML=str;
132
+
133
+ }
134
+
135
+ xhr.send("");
136
+
137
+ }
138
+
139
+ }
140
+
141
+ </script>
142
+
143
+ <h1>Quiz</h1>
144
+
145
+ <h2>一問目:●●●の答えを選んでください。</h2>
146
+
147
+ <input type="radio" name="q1" value="1" />答え1<br />
148
+
149
+ <input type="radio" name="q1" value="2" />答え2が正解<br />
150
+
151
+ <input type="radio" name="q1" value="3" />答え3<br />
152
+
153
+ <h2>二問目:●●●の答えを選んでください。</h2>
154
+
155
+ <input type="radio" name="q2" value="1" />答え1が正解<br />
156
+
157
+ <input type="radio" name="q2" value="2" />答え2<br />
158
+
159
+ <input type="radio" name="q3" value="3" />答え3<br />
160
+
161
+ <input type="button" value="答え合わせ" onclick="ansercheck()" />
162
+
163
+ <div id="kekka"></div>
164
+
165
+ ```