input type="checkbox"でcheckedになった数を計測し、type="radio"では回答に応じて点数を与え、合計値を算出したい
html
1 2<div class="q1"> 3 <p>Bobが好きな乗り物はなんでしょう?</p> 4 <div> 5 <input type="radio" id="bike" name="vehicle" value="1"> 6 <label for="bike">バイク(1点)</label> 7 </div> 8 <div> 9 <input type="radio" id="scooter" name="vehicle" value="2"> 10 <label for="scooter">スクーター(2点)</label> 11 </div> 12 <div> 13 <input type="radio" id="car" name="vehicle" value="3"> 14 <label for="car">車(3点)</label> 15 </div> 16 <div> 17 <input type="radio" id="train" name="vehicle" value="1"> 18 <label for="train">電車(1点)</label> 19 </div> 20</div> 21 22<div class="q2" hidden> 23 <p>Bobが好きな色は何色でしょう?</p> 24 <div> 25 <input type="checkbox" id="black" name="color"> 26 <label for="black">黒</label> 27 </div> 28 <div> 29 <input type="checkbox" id="white" name="color"> 30 <label for="white">白</label> 31 </div> 32 <div> 33 <input type="checkbox" id="blue" name="color"> 34 <label for="blue">青</label> 35 </div> 36 <div> 37 <input type="checkbox" id="yellow" name="color"> 38 <label for="yellow">黄色</label> 39 </div> 40</div> 41<button id="select">ポイント獲得数</button> 42</div>
JavaScript
1document.getElementById('select').onclick = function() { 2 var checkboxes = document.querySelectorAll('input[type="checkbox"]:checked'); 3 alert(checkboxes.length); 4}
結果の例)
Q1
車を選択→3点
Q2
黒と白を選択→2点(各1点)
合計 5点
初心者なりに色々調べた結果、この方法だとinputのタイプに応じてチェックした数を計測できることがわかりました。
しかし、チェックした回答に応じて点数を数値化して与える方法がわかりません。
inputにvalueなどで対応できるのでしょうか?
また、他にも実装してみたい挙動があり、以下の通りです。
ご回答いただけるととても助かります。
チェック前の項目は非表示→チェック後次の項目のみを表示したい
例)
最初はQ1のみ表示→Q1が回答されたら自動でQ2が表示され、Q1は消える
buttonを使わずに、チェックを終えたら自動でチェックリストの下に合計点数に応じたコンテンツを表示したい
例)
チェックボックス 2個
ラジオボタンの得点 3点
合計 5点(「おめでとう!5点獲得です」という画像を表示する)
※コードや数値ではなく画像で表したい
回答2件
あなたの回答
tips
プレビュー