註:jquery版本1.8之後不在支援live事件
在實際專案中遇到的問題,動態新增的標籤
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()對click阻止冒泡有效,那就可以在新動態添加的標籤上綁定click。
以上是jquery阻止事件冒泡及其解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!