セレクトボックスとチェックボックスをある特定の値のときに連動する機能を開発しています。
あくまで例ですが以下のような機能の開発に取り掛かっています。
セレクトボックスで「1」が選択されたとき、チェックボックスにチェックがついてそれ以外が選択された場合はチェックが外れ、逆に以下のチェックボックスがチェックさればセレクトボックスで自動的に「1」が選択されるというものです。
ここで問題点があって、例えば直前にセレクトボックスで3を選んでいて、その後チェックボックスにチェックをつけ、セレクトボックスの値を「1」にした後、またチェックを外すともと入力した値にもどしたいのですが、なかなか苦戦しています。
以下のソースコードのように、変数(inputed)で値を保存しようとしても、そもそもchangeイベントの中に定義しているので値がチェンジのたびに変わってしまいうまくいかず、現在他の方法を考えているのですがなかなかうまくいきません。上記の問題を解決できるようなフォームに直前に入力した値を保存して、元に戻したときにその値を表示することができるような方法を教えて頂きたいです。宜しくお願いします。
JavaScript,jQuery
1<select name="selectbox" id="selectbox"> 2 <option value=""></option> 3 <option value="1">1</option> 4 <option value="2">2</option> 5 <option value="3">3</option> 6 <option value="4">4</option> 7</select> 8<label> 9 <input name="checkbox[]" id="checkbox" value="123" type="checkbox"> 10</label> 11<script type="text/javascript" language="javascript"> 12$(document).on('change','#selectbox', function(){ 13 if ($('#selectbox').val() === '1') { 14 $('#checkbox').prop('checked',true); 15 $('#checkbox').parents('label').addClass("checked"); 16 } else { 17 $('#checkbox').prop("checked",false); 18 $('#checkbox').parents('label').removeClass("checked"); 19 } 20}); 21$(document).on('change','#checkbox', function(){ 22 var inputed = $('#selectbox').val(); 23 if ($('#checkbox').prop('checked')) { 24 $('#selectbox').val('1'); 25 } else { 26 $('#selectbox').val(inputed); 27 } 28}); 29</script>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。