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

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

ただいまの
回答率

90.22%

html読み込み後に、jQueryで追加した要素に対するイベントが動作しない

解決済

回答 3

投稿

  • 評価
  • クリップ 2
  • VIEW 2,047

mulberryfields

score 776

jQueryのappendで、事後的(html読み込み後)に追加した要素をクリックすると、イベントが起こるようにしたいのですが、うまくいきません。
このteratailの質問投稿画面で、「タグ」を追加すると「jQuery  ☓」と表示され、この「☓」をクリックすると、このタグが消えますが、これと全く同じことがしたいです。
(teratailのJavascriptを読み解くことができれば解決できるのですが、分かりませんでした。)

私が書いたコードは、下記のとおりです。
$(function(){
$("#tags").autocomplete({
    source: availableTags,
    autoFocus: true,
     delay: 500,
     minLength: 1,
     select: function(event, ui){
      $("#tagdiv").append("<span class='badge'>selected!  <span class=\"glyphicon glyphicon-remove remove\"></span></span>") 
}
});
});
})
$(function(){
    $("span.remove").on("click",function(){
    $("span.badge").remove();
 });
 });
inputに何らかの文字を打ち込むと、autocompleteで表示がなされ、
例えば「jQuery ☓」のように表示がされます。
この「☓」をクリックすると、「jQuery ☓」が消えてほしいです。
現状では、「☓」をクリックしても何も起きません。

html読み込み時に既にある要素でテストするため、
<span class="remove">test   <span class="glyphicon glyphicon-remove"></span></span>
「test ☓」という記述を予めしておいて、「☓」をクリックしたところ、
うまく消えてくれたので、
jQueryで事後的に追加した要素に対してうまくいかないだけだと思います。

どのように対処すればよいかお分かりの方、ご教示頂けないでしょうか。
よろしくお願いします。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

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

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+2

☓を押下した際の以下のコードを
$(function(){
    $("span.remove").on("click",function(){
    $("span.badge").remove();
 });
 });
↓のように変更するとうまくいくかもしれません。

$(function () {
    $(document).on('click', 'span.remove', function(){
        $("span.badge").remove();
     });
});

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/03 22:31

    できました!ありがとうございました。

    キャンセル

+1

}
});
});
})
一目閉じカッコ多すぎに見えますね。
Syntaxエラーが出てるか確認してみましょう。
ブラウザでAlt+Ctrl+Iか、F12キーを押すとデベロッパーツールが出て来て、エラーが出ていないか確認する事ができますよ。

Netbeansというエディタ(IDE)を使うとその辺もちゃんと見てくれるのでお勧めです。
是非使ってみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/03 22:33

    ありがとうございます。
    カッコの誤りがありました。デベロッパーツールを使って確認するようにします。

    キャンセル

+1

せめてjsで使っている要素のHTMLは提示しないと(Jqueryのバージョンだったり)
デバックがむずかしいですね。

本題の原因は、

Syntaxエラーになっている。

修正後は
<script type="text/javascript" src="jquery-1.11.3.min.js"></script>
<script type="text/javascript" src="jquery-ui-1.11.4/jquery-ui.min.js"></script>
<script type="text/javascript">
$(function(){

    var availableTags = [
      "java",
      "abc"];

    $( "#tags" ).autocomplete({
      source: availableTags,
      autoFocus: true,
      delay: 500,
      minLength: 1,
      select: function(event, ui)
      {
          $("#tagdiv").append("<span class='badge'>selected!  <span class=\"glyphicon glyphicon-remove remove\"></span></span>")
    }
    });
  });


$(function(){
    $ele = $("span.remove");
    $ele.on("click",function(){
    //$("span.remove").on("click",function(){
        $("span.badge").remove();
    })
 });
</script>

<span class="remove">test   <span class="glyphicon glyphicon-remove"></span></span>

<input id="tags" type="text"></input>
<div id="tagdiv"></div>

必要な部分は個人で追加しました。

以上でどうでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/03 22:32

    ありがとうございます。
    今後は、要素のHTMLも記述するようにします。

    キャンセル

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

  • ただいまの回答率 90.22%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる