質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

4998閲覧

フォームに直前に入力した値を一時的に保存したい

alfa

総合スコア12

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2017/01/24 15:21

セレクトボックスとチェックボックスをある特定の値のときに連動する機能を開発しています。

あくまで例ですが以下のような機能の開発に取り掛かっています。
セレクトボックスで「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>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

JavaScript

1$( '#selectbox' ).data( 'inputed', $('#selectbox').val() );

【jQuery.data() | jQuery API Documentation】
https://api.jquery.com/jquery.data/

【jQuery: 特定の要素に関連付くデータを取得/設定するには?(data) - Build Insider】
http://www.buildinsider.net/web/jqueryref/030

【jQueryのdata-*属性キャッシュ仕様と対策】
https://w3g.jp/blog/jquery-data-attr-cache

投稿2017/01/24 15:38

kei344

総合スコア69398

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問