jQueryにてclosestの使いどころとparent / parentsとの違いについて
あるソースコードを見ているとjQueryにてclosest()という使ったことのないメソッドが見受けられた。調べてみると要素から最も近い親要素を取得できるメソッドとのこと。親要素の取得というとparent()を思い浮かべるが挙動はかなり異なるみたい。以下に詳細をメモ。
closest
リファレンス
https://js.studio-kingdom.com/jquery/traversing/closest
ソースコード
<div class="parent_1" data-test="parent_1_2"> <div class="parent_1" data-test="parent_1"> <div class="parent_2" data-test="parent_2"> <div class="parent_3" data-test="parent_3"> <div class="target"> <div class="parent_1" data-test="parent_1_3"></div> </div> </div> </div> </div> </div> <div class="parent_1" data-test="parent_1_2"> <script type="text/javascript" src="https://code.jquery.com/jquery-3.7.1.min.js"></script> <script> $(function(){ console.log($(`.target`).closest(`.parent_1`).data(`test`)); console.log($(`.target`).parent().parent().parent().data(`test`)); console.log($(`.target`).parents(`.parent_1`).data(`test`)); }); </script>
いずれも
解説等
複数階層上がる場合はclosestが簡潔に書ける(parentだと複数回記述しないといけない)。
parentsはセレクタを指定するとclosestと同じように使えるが、指定しない場合は全ての親要素を取得するという違いがある。
関連記事
-
-
「input type="number"」のテキストボックスを桁数制限且つ半角数値のみ入力可にする方法
「input type="number"」のテキストボックスに対して「2桁まで」 ...
-
-
formのtextareaに文字を入力した内容をリアルタイムプレビューする方法
textarea内に書いた内容をリアルタイムでプレビューする機能が必要になった。 ...
-
-
jQuery UIでテキストボックスにサジェスト(入力補助)機能を実装する方法
メールアドレスを入力するためのテキストボックスに文字を入力すると「@yahoo. ...
-
-
セレクトメニュー(プルダウン)をdisplay:none;指定してもiPhoneのみ非表示にならない問題の対応方法
セレクトメニュー(プルダウン)に対してdisplay:none;指定したりjQu ...
-
-
画像をドラッグ&ドロップでアップロード
■2015/04/15追記 以下記事の方が新しくて詳しい。 http://tai ...