jquery的冒泡事件event.stopPropagation()

js中的冒泡事件与事件监听

冒泡事件

js中“冒泡事件”并不是能实际使用的花哨技巧,它是一种对js事件执行顺序的机制,“冒泡算法”在编程里是一个经典问题,冒泡算法里面的冒泡应该 说是交换更加准确;js里面的“冒泡事件”才是真正意义上的“冒泡”,它从DOM最低层逐层遍历树,然后附加相应事件。以下面代码为例:

<title>冒泡事件</title>
<script type="text/javascript">
function Add(sText)
{
    document.getElementByIdx_x_x("Console").innerHTML +=sText;
}
</script>
</head>

<body onclick="Add(’body事件触发<br />’)">
<div onclick="Add(’div事件触发<br />’)">
    <p onclick="Add(’p事件触发<br />’)" style="background:#c00;">点击</p>
</div>
<div id="Console" style="border:solid 1px #ee0; background:#ffc;"></div>
</body>

先执行p的事件,再执行div的事件,最后执行body事件.

事件监听

事件监听准确一点讲可以说是js引擎对用户鼠标、键盘、窗口事件等动作的监视进行的操作,也就是针对用户相应的操作进行附加事件,常用的类似 btnAdd.onclick="alert(’51obj.cn’)"就是一种简单的附加事件,只不过这种方法不支持附加多个事件以及删除事件。以下代 码将实现附加事件后删除事件(IE下):

<script type="text/javascript">
<!–
var oP;
function window.onload(){
    oP=document.getElementByIdx_x_x("pContent");
    oP.attachEvent("onclick",Click);
}
function Click(){
    alert("做点什么吧");
    oP.detachEvent("onclick",Click);
}
//–>
</script>
</head>

<body>
<p id="pContent" style="border:solid 1px #d00; background:#cff;">点击</p>

IE不能称为标准的DOM浏览器,即使是最新的IE8,相对于标准DOM如Firefox、Opera等,它是个“异类”;在Firefox中才真正有称为事件监听的函数addEventListener,如下例

<script type="text/javascript">
<!–
window.onload=function(){
    var oBtn=document.getElementByIdx_x_x("btn");
    oBtn.addEventListener("click",Click,false);
}
function Click(){
    alert("触发click事件");
}
//–>
</script>
<button id="btn">点击</button>

从上面两个例子看出attachEvent在Firefox中并不支持,IE也不支持addEventListener.因此需要使用兼容性的方法。

<script type="text/javascript">
<!–
var oBtn;
window.onload=function(){
    oBtn=document.getElementByIdx_x_x("btn");
    if(window.addEventListener){
        oBtn.addEventListener("click",Click,false);
    }//FF,Opera…
    else if(window.attachEvent){
        oBtn.attachEvent("onclick",Click,false);
    }//IE
    else{
        oBtn.onclick=Click;
    }//Other
}

function Click(){
    alert("事件只执行一次");
    if(window.addEventListener){
        oBtn.removeEventListener("click",Click,false);
    }//FF
    else if(window.attachEvent){
        oBtn.detachEvent("onclick",Click);
    }
    else{
        oBtn.onclick=null;
    }
}
//–>
</script>
</head>

<body>
<button id="btn">www.51obj.cn&raquo;&raquo;</button>
</body>

*************************************************************************

在火狐Firefox、opera、IE下阻止冒泡事件是不同的代码的,火狐下使用的是event.stopPropagation(),而IE下使用的是cancelBubble,jQuery 可以使用e.stopPropagation()就可以兼容了,如果是纯粹的JavaScript需要下面的代码来统一:

if (event.stopPropagation) { 
// this code is for Mozilla and Opera 
event.stopPropagation(); 

else if (window.event) { 
// this code is for IE 
window.event.cancelBubble = true; 
}

//就可以兼容哦 
$("#msg").bind("click", function(e) {   
                            alert("div click");   
e.stopPropagation(); 
  });

*************************************************************************

event.preventDefault()
该方法将通知 Web 浏览器不要执行与事件关联的默认动作(如果存在这样的动作)。例如,如果 type 属性是 "submit",在事件传播的任意阶段可以调用任意的事件句柄,通过调用该方法,可以阻止提交表单。注意,如果 Event 对象的 cancelable 属性是 fasle,那么就没有默认动作,或者不能阻止默认动作。无论哪种情况,调用该方法都没有作用。

event.stopPropagation()
该方法将停止事件的传播,阻止它被分派到其他 Document 节点。在事件传播的任何阶段都可以调用它。注意,虽然该方法不能阻止同一个 Document 节点上的其他事件句柄被调用,但是它可以阻止把事件分派到其他节点。

event是DOM的事件方法,所以不是单独使用,比如指定DOM

时间: 2024-10-09 20:13:25

jquery的冒泡事件event.stopPropagation()的相关文章

jquery阻止冒泡事件:$(&#39;span&#39;).bind(&quot;click&quot;,function(event){event.stopPropagation();})(有用源)

冒泡事件就是点击子节点,会向上触发父节点,祖先节点的点击事件. <body> <div id="content"> 外层div元素 <span>内层span元素</span> 外层div元素 </div> <div id="msg"></div> </body> <script type="text/javascript"> $(funct

JQuery阻止冒泡事件on绑定中异常情况分析

科普下事件冒泡以及默认行为,以下面例子举列子: 事件冒泡:当点击内部button元素时,会触发自身及外层 a的点击事件,这就是事件冒泡引起的.事件会随着 DOM 的层次结构依次向上传播. 事件冒泡可能会引起意料之外的效果,有时候需要阻止事件的冒泡行为. 默认行为:例子中a的href跳转链接就是所谓的默认行为,或者是表单form的提交. JQuery中阻止冒泡常用到的有以下3个方法: 1:event.stopPropagation();  只阻止了冒泡事件, 默认行为没有阻止 2:event.pr

iOS上的jQuery.on()冒泡事件绑定 以及 iOS绝对定位元素中的输入框

上周遇到两个坑. 一是jQuery的on方法 事件冒泡,在iOS中有问题. $("body").on("click",".contentup",Reply.replyOneHandler); 上面这句,在iOS中没有反应.百度和Google了下,没有太权威的解释.只是大概说,iOS的冒泡,如果一直没有handler来处理事件,则只会冒泡到body的内层,而不会冒泡到body上.因此,只好加了个children()这么干了: $("bod

冒泡事件

刚开始的时候,不知道什么是冒泡事件?感觉程序中的应用不会很多,也感觉特别不好理解,没接触到代码是这样理解的:冒泡事件就是触发一个事件,它会相应的一级一级向外冒泡,触发相应的冒泡事件. 一次,查找bug时才有所了解.bug的现象是:某个浏览器中,当"回车"时,页面会报出500的错误,而其他浏览器则不会出现这样的问题.刚开始以为是浏览器兼容的问题,一直向这个方向找错,但是最后师父给看了一下,原来不是浏览器兼容,是冒泡事件. 因为错误是抛到页面上的,说明页面跳转了,不是ajax的异步请求,敲

JavaScript和JQuery中的事件\委托链\事件冒泡\事件捕获,兼容所有浏览器

有做过北大青鸟培训讲师经验的我,如今在一家公司做技术部经理的职位,发现有很多程序员的基本功相当糟糕,在组织企业内部培训时讲解了一些案例,总结了一些经典代码,希望对自己和有需要的人提供一些帮助吧: JavaScript版本: DOM0事件不支持委托链 1 <!DOCTYPE html> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="C

jquery学习(五)-jquery中的事件

参考锋利的jQuery第二版 1.加载DOM (1)执行时机 若想为某个DOM元素绑定事件(或者是其他操作),这需要文档加载完成后才能进行绑定(或其他操作),否则会报错.所以对于这种情况,javascript提供了,window.onload方法:而jQuery提供了,$(document).ready()(简写为$())方法. 虽然这两个方法有类似的功能,但是执行的时机方面还是有区别的.Window.onload方法是在网页所有的元素(包括元素的所有关联文件)完全加载到浏览器后才能执行,即ja

关于js中return false、event.preventDefault()和event.stopPropagation()

在平时项目中,如果遇到需要阻止浏览器默认行为,大家经常会用return false;和event.preventDefault()来阻止,但对它俩的区别还是有些一知半解,于是看了文档,查了些资料,在此总结下它俩的区别,顺便带上event.stopPropagation()一起区分下. 一.原生js中: 关于return false和preventDefault: 在W3C Document Object Model Events Specification1.3版本中提到过: The Event

【Jquery】this和event.target的区别

1.js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化,它永远是直接接受事件的目标DOM元素: 2.this和event.target都是dom对象,如果要使用jquey中的方法可以将他们转换为jquery对象:$(this)和$(event.target); ex: js代码 1 $(function(){ 2 $("li").live("click",function(event){ 3 $("#temp").

冒泡事件详解

这是IE浏览器对事件模型的实现,也是最容易理解的,至少笔者觉得比较符合实际的. 冒泡,顾名思义,事件像个水中的气泡一样一直往上冒,直到顶端. 从DOM树型结构上理解,就是事件由叶子节点沿祖先结点一直向上传递直到根节点:从浏览器界面视图HTML元素排列层次上理解就是事件由具有从属关系的最确定的目标元素一直传递到最不确定的目标元素.冒泡技术.冒泡型事件的基本思想,事件按照从特定的事件目标开始到最不确定的事件目标. 捕获型事件(Event Capturing)Netscape 的实现,它与冒泡型刚好相