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

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

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

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

jQuery

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

Q&A

解決済

4回答

7664閲覧

チェックボックスの値を取得

ryohasegawa

総合スコア437

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2017/09/14 16:23

html

1<input type="checkbox" class="custom-control-input" name="zero" id="zero">

フォームの中にチェックボックスをつけて、以下のコードで値を取得しました。

javascript

1 $(function(){ 2 $('#zero').on('keyup change',function(e){ 3 console.log(e.type+":"+$(this).val()); 4 }); 5 });

すると結果は、以下の写真のようなりなます。*ブラウザの開発ツールです。
イメージ説明
チェックにチェックを入れても外しても、onになります。
チェックが入ったらon 外したらoffにはならないのですか?

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

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

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

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

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

guest

回答4

0

チェックボックスのチェックのON/OFFに関係なく.val()はVALUE値を返します。
例えば、下記のようにVALUEを設定して、ブラウザのデバッグコンソールで$('#zero').val()とタイプしてみてください。戻り値は「1」となると思います。

html

1<input type="checkbox" class="custom-control-input" name="zero" id="zero" value="1">

チェックボックスONの時のVALUE値を知るにはセレクタを使って下記のようにします。チェックボックスOFFの時は値は「undefined」となります。

js

1$('#zero:checked').val();

チェックボックスOFF時に「undefined」がいやなら下記のようにします。

js

1var val = $('#zero:checked').val() || 0;

この仕様は、フォームをPOSTするとわかると思いますが、チェックボックスOFF時はPOSTに含まれません。
チェックボックスはONの時に初めて値がPOSTに含まれるようになります。

投稿2017/09/14 17:11

Tomak

総合スコア1652

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

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

ryohasegawa

2017/09/16 04:30

ありがとうございます。
guest

0

.prop("checked")を使えばチェックが入っていればtrue、チェックが入っていなければfalseが得られます。

lang

1$(function(){ 2 $('#zero').on('keyup change',function(e){ 3 console.log(e.type+":"+$(this).prop("checked")); 4 }); 5});

投稿2017/09/14 16:34

namnium1125

総合スコア2043

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

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

ryohasegawa

2017/09/16 04:31

チェックがされたかされてないかで処理を買えたいので、trueかfolseで使えるのがいいですね。
guest

0

ベストアンサー

onやoffは明示的に文字列として持ってやったほうがいいでしょうね

javascript

1$(function(){ 2 $('#zero').on('change',function(e){ 3 console.log(e.type+":"+($(this).prop("checked")?$(this).val():$(this).data("not-checked"))); 4 }); 5});

html

1 2<input type="checkbox" id="zero" value="on" data-not-checked="off">

投稿2017/09/15 00:25

yambejp

総合スコア114572

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

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

ryohasegawa

2017/09/16 04:33

質問の答えをありがとうございます。 ($(this).prop("checked")?$(this).val():$(this).data("not-checked"))なんですが、prop("checked")がtrueだったら(this).val()をfalseだったら$(this).data("not-checked")を実行るつ処理ですよね?
guest

0

checkboxのvalue未設定時はデフォルト値の"on"が入ります。
val()はただvalueの値を表示するだけの関数です。

投稿2017/09/14 18:38

OldRiver

総合スコア59

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問