jQueryの発火する方法について質問です。
理想としては、input[type="hidden"]
のvalue
の値が変更したタイミングで、「小計¥」の計算が行われるコードを書きたいです。
下記に現在のコードを全て書き写しました。
内容としては、input[type="radio"]
をチェックしてinput[type="hidden"]
のvalue
の値を書き換え、全てのinput[type="hidden"]
のvalue
の値を足した数字が「小計¥」にリアルタイムで表示する仕様です。
index.html
1 2 <main id="main"> 3 <div id='app'> 4 <div class="box"> 5 6 <input type="radio" name="model" value="100"> 7 <input type="radio" name="model" value="200"> 8 <input type="radio" name="model" value="300"> 9 <input type="hidden" name="" value="0"> 10 </div> 11 <div class="box"> 12 13 <input type="radio" name="rank" value="400"> 14 <input type="radio" name="rank" value="500"> 15 <input type="radio" name="rank" value="600"> 16 <input type="hidden" name="" value="0"> 17 </div> 18 <div class="box"> 19 20 <input type="radio" name="jamp" value="400"> 21 <input type="radio" name="jamp" value="500"> 22 <input type="radio" name="jamp" value="600"> 23 <input type="hidden" name="" value="0"> 24 </div> 25 <div class="box"> 26 27 <input type="radio" name="bomb" value="400"> 28 <input type="radio" name="bomb" value="500"> 29 <input type="radio" name="bomb" value="600"> 30 <input type="hidden" name="" value="0"> 31 </div> 32 <div class='text-right'> 33 <p> 小計¥ <span id="sum">0</span></p> 34 <p>消費税¥ <span id="tax">0</span></p> 35 <p> 合計¥ <span id="all">0</span></p> 36 </div> 37 </div> 38 </main> 39 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script> 40 <script> 41 $(function() { 42 43 $('input[type="radio"]').change(function() { 44 45 // input radioのvalueの値を、input hiddenに入れる 46 var number = $(this).val(); 47 var scores = []; 48 $(this).parent().children('input[type="hidden"]').val(number); 49 50 // 全てのinput hiddenを配列に入れ、配列の値を足す 51 $('input[type="hidden"]').each(function() { 52 scores.push(Number($(this).val())); 53 }); 54 sum = scores.reduce((a,x) => a+=x,0); 55 56 // 小計の計算 57 $("#sum").text(sum); 58 $("#tax").text($("#sum").text() * 0.1); 59 $("#all").text(Number($("#sum").text()) + Number($("#tax").text())); 60 }); 61 62 }); 63 64 </script> 65
現在も、発火するタイミングをinput[type="radio"].change
にすることで、問題なく動いております。
しかし、理想としては「小計¥」の計算のみ、input[type="hidden"]
のvalue
の値が変わったタイミングで値を変える仕様にしたいです。
理由としては、今後追加するコードの中に、input[type="radio"]
にクリックせずにinput[type="hidden"]
のvalue
の値を変更する機能も実装するため、上記の状態だと「小計¥」の値がリアルタイムで変更されないことが起こってしまうからです。
当たり前かもしれませんが、下記のようにコードを書いてみましたがダメでした。
index.html
1 <script> 2 3 $(function() { 4 5 $('input[type="radio"]').change(function() { 6 7 // input radioのvalueの値を、input hiddenに入れる 8 var number = $(this).val(); 9 var scores = []; 10 $(this).parent().children('input[type="hidden"]').val(number); 11 12 // 全てのinput hiddenを配列に入れ、配列の値を足す 13 $('input[type="hidden"]').each(function() { 14 scores.push(Number($(this).val())); 15 }); 16 sum = scores.reduce((a,x) => a+=x,0); 17 }); 18 19 $('input[type="hidden"]').change(function() { 20 // 小計の計算 21 $("#sum").text(sum); 22 $("#tax").text($("#sum").text() * 0.1); 23 $("#all").text(Number($("#sum").text()) + Number($("#tax").text())); 24 25 }); 26 27 }); 28 </script>
もし、input[type="hidden"]
のvalue
の値が変わったタイミングで発火する方法があれば教えていただけると幸いです。
回答2件
あなたの回答
tips
プレビュー