ホームページ > ウェブフロントエンド > jsチュートリアル > クリックを使用してjQueryによってバインドされたイベントが無効なのはなぜですか?

クリックを使用してjQueryによってバインドされたイベントが無効なのはなぜですか?

黄舟
リリース: 2017-06-27 10:14:24
オリジナル
2343 人が閲覧しました

jqueryclickを使用したイベントのバインドは無効です

$(this).children(":last").prev().after("<div class=&#39;bounty-add&#39;><a target=&#39;_blank&#39; href=&#39;bounties.php#/p=add&XID=" + playerId + "&#39;>[Bounty]</a></div>"); 
$(this).children(":last").prev().after("<div class=&#39;info-add&#39;><a href=&#39;#&#39;>[Refresh]</a></div>");        
$("div.bounty-add").css(addStyle);
$("div.info-add").css(addStyle);
         
         
$(this).children(":last").prev().children("a").click(function() {
   alert("Hello");
});
ログイン後にコピー

関連する基本的なコードは上記の通りでスムーズに要素を取得できますが、Chromeの「Elements」ではバインドされたクリックイベントが無効です。 「ツール」「イベント リスナー」でも有効なバインディングが見つかりませんでした。
上記の基本コードで追加された DOM はすべて有効です。外側の層は 2 つのループ ですが、バインディング ステップを含むすべてのコードはスムーズに実行できるはずです。実行が完了しても a 要素をクリックしても無効となり、バインドされた関数が見つかりません。 。 。 。 。 。 。

$(this).children(":last").prev().children("a").on("click",function() {
   alert("Hello");
});
ログイン後にコピー
ログイン後にコピー

onも試してみましたがダメでした この2つは基本的に同じでしょうか?
a 要素自体にはクリック可能な 属性 があるため、クリック後も元のイベント (href=‘#’ など) に応答し、アドレス バーの末尾に # が追加されます。 。 。 。元のイベントが後から追加したイベントを上書きしてしまうからでしょうか? 。 。 。 。 。

以前のバインディングは

$(this).children(":last").prev().children("a").on("click",function() {
   alert("Hello");
});
ログイン後にコピー
ログイン後にコピー

通常のクリックバインディングと同じでした
このようにバインドしてみてください

$(this).on("click",".info-add a",function() {
   alert("Hello");
});
ログイン後にコピー

要素は動的に生成されていますか?
その場合は、ライブ バインディングまたはデリゲート バインディングを使用してください

ライブ jquery1.9 は削除されました。これは、要素が見つからない、またはバインドできないということではなく、バインド後に無効になるということです。
クリックリスナーにも含まれる a 要素を p 要素に直接変更しましたが、どうしても alter("hello"); がトリガーされません。 。 。 。 。 。

まず、firebugを使用して、ページにスクリプト エラーがあるかどうかを確認します
もう一度、コードで a 要素が見つかったことを確認します
最後に。

$(document).on("click",".info-add",function(){
alert("ok")
})
ログイン後にコピー
を使用できます

うまくいかない場合は、完全なコードを送ってください

以上がクリックを使用してjQueryによってバインドされたイベントが無効なのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート