注: jquery はバージョン 1.8 以降、ライブイベントをサポートしなくなりました
実際のプロジェクトで発生した問題、動的に追加されたタグ
Live はバブリングの発生を防ぎます。 return false も e.stopPropagation() もバブリングの発生を防ぐことはできません
以下は私がまとめた例です
<p id="box"> <a href="javascript:;" class="delete">init html</a> </p> <button id="add">add html</button>
$(function() { // 用click事件 $(document).click( function(event) { console.log('click'); event.stopPropagation(); }); // 用delegate事件 $(document).delegate('.delete','click', function(event) { console.log('delegate'); event.stopPropagation(); }); // 用live事件 $('.delete').live('click', function(event) { console.log('live'); event.stopPropagation(); //return false; }); // 新添加的a标签 $('#add').click(function() { var html = '<a href="javascript:;" class="delete">new html 1</a>'; $('#box').append(html); }); $('#box').click(function() { console.log('box emit'); }); });
解決策:
event.stopPropagation() がクリックに対してバブリングを防ぐのに効果的であることがわかっているので、新しく動的に追加されたラベルにクリックイベントをバインドできます。
以上がjqueryによるイベントバブリングの防止とその解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。