<html> <script type="text/javascript" src="jquery-1.7.1.js"></script> <script> function ialertdouble(e) { alert('innerdouble'); stopBubble(e); } function ialertthree(e) { alert('innerthree'); stopBubbleDouble(e); } function stopBubble(e) { var evt = e||window.event; evt.stopPropagation?evt.stopPropagation():(evt.cancelBubble=true);//阻止冒泡 } function stopBubbleDouble(e) { var evt = e||window.event; evt.stopPropagation?evt.stopPropagation():(evt.cancelBubble=true);//阻止冒泡 evt.preventDefault();//阻止浏览器默认行为,这样链接就不会跳转 } $(function() { //方法一 //$('#jquerytest').click(function(event) { // alert('innerfour'); // event.stopPropagation(); // event.preventDefault(); //}); //方法二 $('#jquerytest').click(function() { alert('innerfour'); return false; }); }); </script> <div onclick="alert('without');">without <div onclick="alert('middle');">middle <div onclick="alert('inner');">inner</div> <div onclick="ialertdouble(event)">innerdouble</div> <p><a href='http://www.baidu.com' onclick="ialertthree(event)">innerthree</a></p> <p id='jquerytest'><a href='http://www.baidu.com'>innerfour</a></p> </div> </div> </html>当你点击inner的时候,会依次弹出‘inner’,‘middle’和‘without’。这就是事件冒泡。
event.stopPropagation(); event.preventDefault(); //没有链接不需要加这个。这样就可以了。
$('#id').click(function(event){ if(event.target==this){ //do something } })解析:事件处理程序中的变量event保存着事件对象。而event.target属性保存着发生事件的目标元素。这个属性是DOM API中规定的,但是没有被所有浏览器实现 。jQuery对这个事件对象进行了必要的扩展,从而在任何浏览器中都能够使用这个属性。通过.target,可以确定DOM中首先接收到事件的元素(即实际被单击的元素)。而且,我们知道this引用的是处理事件的DOM元素,所以可以编写以上代码。
不过推荐使用return false,Jquery绑定事件的话。
已有1条评论