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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

解決済

jQueryの簡単な .prepend がなぜかできません

nikuatsu
nikuatsu

総合スコア172

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

2回答

0リアクション

0クリップ

189閲覧

投稿2022/09/27 06:31

前提

ボタンクリックで指定クラスの要素を.prependするというだけの機能を作っています。

実現したいこと

クリックする限り、.prependし続けたいです。

発生している問題

1回しか.prependされません。

該当のソースコード

ボタンクリックで.pepnedするだけの簡易なコードです。

https://jsfiddle.net/Lcea4m9j/

html

<ul> <li>A</li> <li class="target">B</li> <li>C</li> </ul> <input type="text" value="3"> <button>Bをリストの上にn件追加</button>

JavaScript

$('button').click(function(){ const n = $('input').val(); for (let i = 1; i < n; i++){ $('ul').prepend( $('.target') ); } });

試したこと

コンソールを見ると条件は問題なく通っているように見えます。
つまり「n」の数だけ「追加します」と出力されます。

JavaScript

$('button').click(function(){ const n = $('input').val(); console.log(n); for (let i = 1; i < n; i++){ console.log('追加します'); $('ul').prepend( $('.target') ); } });

1回しかできないので、2回目はクラスが複数あることが原因か?と思い、次のように.eq()で一つだけ指定してみましたがダメでした。

JavaScript

$('ul').prepend( $('.target').eq(0) ); // .eq(0) で一つだけ指定してみた

なんとなく.ouerHTMLも書いてみましたがダメでした。

JavaScript

$('ul').prepend( $('.target').eq(0).outerHTML ); // .ouerHTMLも書いてみた

こんなの全然簡単でしょ、と高を括っていたのですが、どうしてできないのでしょうか?

バージョン

jQuery 3.6.0

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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