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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

3回答

863閲覧

jQuery $(this)から見て、親の兄弟の孫要素を取得したい

aaaas_s

総合スコア7

jQuery

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2018/02/02 03:07

前提・実現したいこと


http://kanahebiz.hatenablog.com/entry/2015/10/08/121404

を参考にした、複数チェックボックスの、全選択、全解除ができるチェックボックスを作っています。やりたいことは上記のURLがわかりやすいと思います。

ただ、例に挙げたURLと違い、そのチェックボックス群が複数ある想定です。

ソースがこちらになります。

html

1<div class="wrap_block_list"> 2 <ul class="block_list"> 3 <li> 4 <h5> 5 <input type="checkbox" name="syurui" class="parent_check" value="全て"> 6 <a href=""> 7 全て 8 </a> 9 </h5> 10 <ul class="child_check_ul"> 11 <li> 12 <input type="checkbox" class="child_check" value="とんこつ"> 13 <a href=""> 14 とんこつ 15 </a> 16 </li> 17 <li> 18 <input type="checkbox" class="child_check" value="味噌"> 19 <a href=""> 20 味噌 21 </a> 22 </li> 23 <li> 24 <input type="checkbox" class="child_check" value="醤油"> 25 <a href=""> 26 醤油 27 </a> 28 </li> 29 <li> 30 <input type="checkbox" class="child_check" value=""> 31 <a href=""> 3233 </a> 34 </li> 35 </ul> 36 </li> 37 </ul> 38</div> 39<br> 40<div class="wrap_block_list"> 41 <ul class="block_list"> 42 <li> 43 <h5> 44 <input type="checkbox" class="parent_check" value="全て"> 45 <a href=""> 46 全て 47 </a> 48 </h5> 49 <ul class="child_check_ul"> 50 <li> 51 <input type="checkbox" class="child_check" value="とんこつ"> 52 <a href=""> 53 とんこつ 54 </a> 55 </li> 56 <li> 57 <input type="checkbox" class="child_check" value="味噌"> 58 <a href=""> 59 味噌 60 </a> 61 </li> 62 <li> 63 <input type="checkbox" class="child_check" value="醤油"> 64 <a href=""> 65 醤油 66 </a> 67 </li> 68 <li> 69 <input type="checkbox" class="child_check" value=""> 70 <a href=""> 7172 </a> 73 </li> 74 </ul> 75 </li> 76 </ul> 77</div> 78<br> 79<div class="wrap_block_list"> 80 <ul class="block_list"> 81 <li> 82 <h5> 83 <input type="checkbox" class="parent_check" value="全て"> 84 <a href=""> 85 全て 86 </a> 87 </h5> 88 <ul class="child_check_ul"> 89 <li> 90 <input type="checkbox" class="child_check" value="とんこつ"> 91 <a href=""> 92 とんこつ 93 </a> 94 </li> 95 <li> 96 <input type="checkbox" class="child_check" value="味噌"> 97 <a href=""> 98 味噌 99 </a> 100 </li> 101 <li> 102 <input type="checkbox" class="child_check" value="醤油"> 103 <a href=""> 104 醤油 105 </a> 106 </li> 107 <li> 108 <input type="checkbox" class="child_check" value=""> 109 <a href=""> 110111 </a> 112 </li> 113 </ul> 114 </li> 115 </ul> 116</div>

javascript

1$(function() { 2 $('.parent_check').on('click', function () { 3 $(this).parent("h5").next(".child_check_ul").find('.child_check').prop('checked', this.checked); 4 }); 5 6 $('.child_check').on('click', function () { 7 if ($('.child_check_ul :checked').length == $('.child_check_ul :input').length) { 8 $(this).parents(".child_check_ul").prev("h5").find('.parent_check').prop('checked', 'checked'); 9 } else { 10 $(this).parents(".child_check_ul").prev("h5").find('.parent_check').prop('checked', false); 11 } 12 }); 13});

質問したいのが、この上記のjsの

javascript

1$(this).parent("h5").next(".child_check_ul").find('.child_check').prop('checked', this.checked);

javascript

1 $(this).parents(".child_check_ul").prev("h5").find('.parent_check').prop('checked', false);

の部分になります。

例のURLとは違い複数個あるため、$(this)を使って指定をしないと、.parent_checkを押した時に、どの.child_checkも反応してしまうため、このように記述しました。

しかしこの書き方で2点問題が出てきました。

①例えば、「全て」のチェックをおした後に「とんこつ」のチェックを外し、更に「とんこつ」を押したら、本当は「全て」にチェックが入って欲しいのに「全て」にチェックが入りません。

②parent,next,findと、指定の方法が長すぎてもっと綺麗に書けるのではと考えています。

いろいろ検索しましたがわからなかったため、この2点についてお聞きしたいです。

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

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

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

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

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

guest

回答3

0

ベストアンサー

ものぐさな私は兄弟とか考えずに親まで戻ってfindしてしまいますね。
yambejp氏のコードを拝借。

javascript

1$(function(){ 2 $('.parent_check').on('change', function () { 3 $(this).parents('.block_list').find(".child_check").prop('checked', $(this).prop('checked')); 4 }); 5});

jsfiddle

投稿2018/02/02 04:28

sousuke

総合スコア3828

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

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

0

作りが決まってるならclosest()やfind()を使って書けばいいのでは?

JavaScript

1 $('.parent_check').on('click', function () { 2 $(this).closest('.block_list').find('.child_check').prop('checked', this.checked); 3 }); 4 5 $('.child_check').on('click', function () { 6 var ul = $(this).closest('.block_list'); 7 ul.find('.parent_check').prop('checked', ul.find('.child_check:checked').length === ul.find('.child_check').length); 8 });

投稿2018/02/02 04:25

x_x

総合スコア13749

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

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

0

親の兄弟の孫であればこうでは?

javascript

1$(function(){ 2 $('.parent_check').on('change', function () { 3 $(this).parent().siblings().children().children().prop('checked', $(this).prop('checked')); 4 }); 5});

投稿2018/02/02 03:19

yambejp

総合スコア114583

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

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

x_x

2018/02/02 03:28

なぜchangeに変更したのでしょうか?
yambejp

2018/02/02 03:35

changeイベントをもっているnodeならclickよりchangeの方が トリガーの使い勝手がよくないですか? たとえば $('.parent_check').on('change', function () { ・・・ }).trigger('change'); のように、任意にchangeを発火させることもありますし trigger('click')するとホントにクリックされちゃうのでNG
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問