🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
jQuery

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

Q&A

解決済

1回答

6632閲覧

tableのチェックボックスのチェック状態を取得したい

chintao1224

総合スコア156

jQuery

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

0グッド

0クリップ

投稿2021/03/12 06:12

編集2021/03/12 06:25

tableにcheckboxを表示しています。
全行ループしながらcheckboxのチェック状態を取得したいです。

html

1<table class="list"> 2<thead> 3<th>col0</th> 4<th>col1</th> 5<th>col2</th> 6<th>col3</th> 7</thead> 8<tbody> 9<tr> 10<td><input type="checkbox" class="chk" /></td> 11<td>11</td> 12<td>12</td> 13<td>13</td> 14</tr> 15<tr> 16<td><input type="checkbox" class="chk" /></td> 17<td>21</td> 18<td>22</td> 19<td>23</td> 20</tr> 21<tr> 22<td><input type="checkbox" class="chk" /></td> 23<td>31</td> 24<td>32</td> 25<td>33</td> 26</tr> 27</tbody> 28</table>

jquery

1for(var i=1; i < ($(".list tbody").children().length + 1); i++){ 2 if($(".list tr:eq(" + i + ") td:eq(0)").prop()=="checked"){ 3 temp = "1"; 4 } else { 5 temp = "0"; 6 } 7}

何とか指定行のチェックボックスのチェック状態を取得したいです。
上記ではうまくいきませんでした。

どうすればよいか教えてください。
よろしくお願いします。

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

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

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

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

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

m.ts10806

2021/03/12 06:18

.listはhtml上にないようです。 .chkを直接見に行けばいいように思いますが、用途に合わないですか?
chintao1224

2021/03/12 06:29

$(.chk).prop()という見方になるのでしょうか。
ku__ra__ge

2021/03/12 08:09

"jquery prop"で検索をしてみてください。propメソッドは、$(.chk).prop()という書き方で利用することはできません。
guest

回答1

0

ベストアンサー

:checkedというセレクタが便利ですよ。
https://api.jquery.com/checked-selector/

セレクタとしても使えるし、セレクトしたあとでis()することもできます。
いくつか使用例を挙げます。

javascript

1$('.chk').each((i,e)=>{ 2 console.log(i + '番目は、チェック' + 3 ($(e).is(':checked') ? 'されてます' : 'されてません')); 4}); 5 6console.log('全部で' + $('.chk:checked').length + '個チェックされてます'); 7 8let flags = $('.chk').map((i,e)=>$(e).is(':checked')).toArray(); 9console.log(flags);

投稿2021/03/12 10:56

gpsoft

総合スコア1323

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

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

chintao1224

2021/03/12 14:14

ありがとうございます。 チェックされていてもチェックされていなくても全行のチェック状態を取得したかったので以下のようにしてみましたが、どうしてもtempに"0"が入ってしまいます。 if($(".list tr:eq(" + i + ") td:eq(0)").prop('checked')){ temp = "1"; } else { temp = "0"; } 何が良くないのか教えてもらえないでしょうか。
gpsoft

2021/03/12 23:10

惜しいです。 このコードだと、td要素が選択されてしまうので、prop('checked')は常にfalseになります。 td要素の中のinput要素が選択されるようにセレクタを修正してみてください。
chintao1224

2021/03/13 03:02

できました。ありがとうございました。 if($(".conditionlist tr:eq(" + i + ") td input[type='checkbox']").prop('checked') == true){
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問