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

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

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

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

Q&A

解決済

1回答

1838閲覧

jQueryで特定の子要素がない場合の処理

hayamin1111

総合スコア11

jQuery

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

0グッド

0クリップ

投稿2021/04/18 07:49

編集2021/04/18 09:23

jQueryにて、特定の子要素がなければ、親要素にクラスを付与する方法を探しています。
下記のコードで、要素3のliにのみクラスをつける方法です。

HTML

1<ul> 2 <li> 3   <a>要素1</a> 4   <button>ボタン1</button> 5 </li> 6 <li> 7   <a>要素2</a> 8   <button>ボタン2</button> 9 </li> 10 <li><a>要素3</a></li> 11</ul>

試したこと

取得したliをeachで1つずつ処理をし、has('button')でbutton要素を持っていなければ、activeクラスを付与、としたかったが、クラスは付与されず、変化はなにもない(エラーは出ていない)。

jQuery

1$(window).on('load', function() { 2 var lists = $('ul > li'); 3 lists.each(function(index, elem) { 4 if(!$(elem).has(button)) { 5 $(elem).addClass('active'); 6 } 7 }); 8});

each文の代わりにfor文でも試したが、同様の結果。

jQuery

1$(window).on('load', function() { 2  var lists = $('ul > li'); 3  for(var i = 0; i < lists.length; i++) { 4   if(!$(lists[i]).has(button)) { 5    $(lists[i]).addClass('active'); 6   } 7  } 8});

試しにif文の条件から'!'を外してみると、全てのliにクラスが付与されてしまった。

jQuery

1$(window).on('load', function() { 2 var lists = $('ul > li'); 3 lists.each(function(index, elem) { 4 if($(elem).has(button)) { 5 $(elem).addClass('active'); 6 } 7 }); 8});

has()ではない方法があるのでしょうか。どなたかご教示いただけると幸いです。

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

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

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

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

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

satokei

2021/04/18 08:06

要素3の li にも a要素はあるようですが...
int32_t

2021/04/18 08:20

変数 a に 'button' が入っているということでしょうか。
hayamin1111

2021/04/18 09:16

失礼いたしました。 おっしゃる通りaではなくbuttonです。 has(button)と読み替えていただけると幸いです。
satokei

2021/04/18 09:34

質問は編集できますので、修正してください。
satokei

2021/04/18 09:35

すみません。修正していただいていましたね。
guest

回答1

0

ベストアンサー

以下のコードでできると思います。

js

1$(window).on('load', function() { 2 $('ul > li:not(:has(button))').addClass('active'); 3});

投稿2021/04/18 09:34

satokei

総合スコア1217

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

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

hayamin1111

2021/04/18 09:45

ご回答ありがとうございます。 試したところ、無事解決できました。 CSSの擬似クラスを使うというのは盲点でした。 大変助かりました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問