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

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

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

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

Q&A

解決済

1回答

1355閲覧

jQueryのループ処理で、最後の要素にしか処理がされない理由

kata2murin

総合スコア22

jQuery

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

1グッド

0クリップ

投稿2020/06/25 21:08

以下のjQueryについて、最後のulappend()されるliにしか、.slideaddClass()されないのはなぜですか?

html

1<ul></ul> 2<ul></ul>

jQuery

1 2var arr = ['a']; 3 4for(var i = 0; i < arr.length; i++){ 5 6 var slide_box = $("<li>"), 7 slideshow = $("ul"); 8 9 slide_box.html(arr[i]); 10 slideshow.append(slide_box); 11 12 slideshow.find(slide_box).addClass("slide"); 13};

最後の行を以下にすれば.slideはすべてにaddClass()されます。
よって上のコードはslideshowからfind()できていないのだとわかりますが、
しかしなぜfind()できないのかがわかりません。

jQuery

1// slideshow.find(slide_box).addClass("slide"); 2slideshow.find("li").addClass("slide");
ohys👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

【jqueryオブジェクト】を、複数の対象に対して一度に.append()する場合、
複数の対象の中の「最後の対象」以外に.append()されるのは、
【jqueryオブジェクト】のクローン(複製)だからです。

つまり

HTML

1<ul id="UL_1"></ul> 2<ul id="UL_2"></ul> 3<ul id="UL_3"></ul>

に対して、

javascript

1<script> 2 var $li= $("<li>"); 3 $('ul').append($li); 4</script>

とするは、

javascript

1<script> 2 var $li = $("<li>"); 3 4 //最後じゃないのは、複製をいれて 5 $('#UL_1').append($li.clone()); 6 $('#UL_2').append($li.clone()); 7 8 //最後は、本体をいれる 9 $('#UL_3').append($li); 10</script>

としていることになります。

「複製$li.clone()」は、「本体$li」とは違うものなので

javascript

1<script> 2 var $li= $("<li>"); 3 $('ul').append($li); 4 5 //本体を指定してクラスを追加 6 $('ul').find($li).addClass('test'); 7</script>

で、「本体$li」にのみクラスが付与されるのは、
書いた通りに動いた結果・・ということになりますね。

投稿2020/06/26 00:21

mix-peach

総合スコア1910

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

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

kata2murin

2020/06/26 00:25

いや~、これはまったく知らなかったです。とても勉強になりました。ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問