`
日光浴的猪
  • 浏览: 16881 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

javascript 冒泡

阅读更多

昨天学习了一下javascript的冒泡,和大家分享在这里,有异议的请留言讨论。

 

什么是冒泡

简单的说就是触发一个子容器的事件,父容器的事件也会跟着被触发。

 

如下图:


 

 <div id="parentDiv" onclick="alert('parent');">       parent 
       <div id="childDiv" onclick="alert('child');">child</div>
  </div>

 

 

 

我们在child和parent上分别添加了alert('child')和alert('parent')事件,这个时候假如我们点击child,会先执行alert('child'),然后父元素的alert('parent')也会被执行,当然假如还有更多的层次,父级的事件会依次被触发,这就是冒泡。

 

但有些时候我么会不需要这样的机制,不如我们点击child只想触发child上的alert('child')事件,那么我们就要阻止冒泡的发生,做法如下。

 

 

如何阻止冒泡?

阻止冒泡有两种方法

e.cancelBubble=true;

e.stopPropagation();

 

据说e.stopPropagation();是针对firefox的,e.cancelBubble=true;是针对IE的。

但经过我测试了一下这两个方法在iefirefoxoperachrome上都可用,可能会根据版本有差异吧,大家自己判断吧

 

下面举个例子

 

    <div id="parentDiv" onclick="alert('parent');">
       parent
       <div id="childDiv" onclick="doSomething(this,event);">child</div>
    </div>

 

 

 

function doSomething (obj,evt) {
    var e=evt||window.event;
    e.stopPropagation();
}

 

因为在doSomething里阻止了冒泡,所以parentDiv上的alert('parent')事件也就不会被触发了。

 

如何利用冒泡?

当然有的时候我们还会利用一下冒泡,满足我们的需求,比如有很多个元素都要添加一个事件来处理某件事,但是假如把某个元素上都加上onclick的话,首先性能不说,这么多的代码也会让人嗤之以鼻,这就可以用到冒泡。

 

因为这些元素事件的触发都能够通过冒泡来触发他父亲的事件,那就只给他父亲加上事件吧,然后再判断确切是那个元素的时间被触发。然后你就可以为所欲为了。

 

例子:

 

    <table onclick="clicktd(event);" width="400" height="200" border="1">
    <tr>
    <td id="td1" width="25%">td1</td>
    <td id="td2" width="25%">td2</td>
    <td id="td3" width="25%">td3</td>
    <td id="td4" width="25%">td4</td>
    </tr>
    </table>

 

function clicktd(e){
     e = e || window.event;
var obj =  e.target || e.srcElement;
alert(obj.id);
}
  

这里主要是通过e.target e.srcElement(根据浏览器不同)获取确切的元素。接下来怎么做大家应该知道了。

 

 

最后来个例子的集合

<html>
  <head>  
  <style>
  #parentDiv{width:200px;height:200px;background:#666;}
  #childDiv{width:100px;height:100px;background: #06C; margin:50px;}
  </style>
  </head>
  <body>
  
  没被阻止冒泡的:
    <div id="parentDiv" onclick="alert('parent');">
       parent 
       <div id="childDiv" onclick="alert('child')">child</div>
    </div>
  
  <br/>
  被阻止冒泡的:
    <div id="parentDiv" onclick="alert('parent');">
       parent 
       <div id="childDiv" onclick="doSomething(this,event);">child</div>
    </div>
   
    <br/>
    冒泡的应用:
    <table onclick="clicktd(event);" width="400" height="200" border="1">
    <tr>
    <td id="td1" width="25%">td1</td>
    <td id="td2" width="25%">td2</td>
    <td id="td3" width="25%">td3</td>
    <td id="td4" width="25%">td4</td>
    </tr>
    </table>
   
    <script>
	function doSomething (obj,evt) { 
		var e=evt||window.event; 
		alert("child");
	    e.stopPropagation();
	
} 
	
	function clicktd(e){
        e = e || window.event;
		var obj =  e.target || e.srcElement;
		alert(obj.id);
	}
    </script>
  </body>
</html>
 
  • 大小: 1.7 KB
2
0
分享到:
评论
1 楼 caoxiaoj2ee 2012-02-22  
好东西,好

相关推荐

    javascript冒泡排序源代码

    直接运行html 文件即可,第一个文本框为要排序的数字,第二位为排序后的现实的地方

    JavaScript冒泡排序1

    JavaScript中的冒泡排序是一种基础且常见的排序算法,它的工作原理是通过不断交换相邻的不正确顺序的元素,使得较大的元素逐渐“冒”到数列的末尾,从而达到排序的目的。冒泡排序的时间复杂度在最坏的情况下为O(n^2)...

    javascript冒泡排序基本代码

    冒泡排序

    Javascript冒泡排序算法详解

    在Javascript中实现冒泡排序算法,通常需要通过双层嵌套的for循环来完成。外层循环控制排序的总轮数,内层循环负责每一轮的比较和交换。每一轮排序后,最大的数会被放置在当前未排序的数列的末尾。随着外层循环的...

    javascript冒泡排序小结

    冒泡排序由于比较简单和容易理解,往往会成为人们首先想到的排序算法。最基本的想法就是在一次里面比较两个数字,并且确保他们在移动到其他项目之前有一个正确的顺序。在每一关结束,有价值的“排序”到正确的位置,...

    JavaScript冒泡算法原理与实现方法深入理解

    JavaScript冒泡排序算法是一种基础的排序算法,其主要思想是通过重复遍历待排序的数列,比较相邻的元素并根据需要交换它们的位置,直到数组中的所有元素都按指定顺序排列。这种算法的名字来源于排序过程中较小的元素...

    js冒泡排序两种排序代码

    js冒泡排序,冒泡排序的工作原理,我们有一个未排序的数组arr = [ 1, 4, 2, 5, -2, 3 ]任务是使用冒泡排序对数组进行排序。 冒泡排序比较索引 0 中的元素,如果第 0 索引大于第 1 索引,则交换值,如果第 0 索引...

    关于IE浏览器以及Firefox下的javascript冒泡事件的响应层级

    JavaScript中的事件冒泡是Web开发中的一个重要概念,它涉及到事件如何在DOM(文档对象模型)树中从最具体的节点向最不具体的节点传播。事件冒泡是指事件开始时由最具体的元素(文档中嵌套层次最深的那个节点,通常是...

    JS实现冒泡排序,前端必会

    以下是一个基本的JavaScript冒泡排序函数实现: ```javascript function bubbleSort(arr) { var len = arr.length; for (var i = 0; i ; i++) { for (var j = 0; j ; j++) { if (arr[j] &gt; arr[j + 1]) { var ...

    关于javascript冒泡与默认事件的使用详解

    JavaScript中的冒泡与默认事件是理解事件处理机制的关键概念,尤其在构建交互式的网页应用时。本文将深入探讨这两个概念,并通过示例代码进行详细解释。 首先,让我们了解什么是事件冒泡。事件冒泡是指当一个事件...

    通过javascript实现冒泡排序.rar

    压缩包js文件是一个使用JavaScript实现冒泡排序的示例代码。这个实现的时间复杂度在最坏情况下是 O(n^2),其中 n 是数组的长度。尽管冒泡排序不是最高效的排序算法,但由于其实现简单,对于小规模数据的排序仍然是一...

    JavaScript 冒泡排序和选择排序的实现代码

    JavaScript中的冒泡排序和选择排序是两种常见的简单排序算法,它们在处理数组排序时各有特点。下面我们将详细探讨这两种排序算法以及它们的实现代码。 **冒泡排序(Bubble Sort)** 冒泡排序是一种通过重复遍历...

    javascript 冒泡排序 正序和倒序实现代码

    在JavaScript中,冒泡排序可以实现升序(正序)和降序(倒序)两种排序方式。 首先,我们来看一下冒泡排序实现升序排序的原理。在升序排序中,我们需要比较数组中的相邻元素,如果当前元素比下一个元素小,那么就...

    JavaScript事件冒泡示例.html

    JavaScript事件冒泡是Web开发中的一个关键概念,它在网页交互和动态效果中扮演着重要角色。事件冒泡源于浏览器处理事件的方式,当一个事件(如点击、鼠标移动等)在一个元素上触发时,该事件会自底向上沿着DOM树...

    JavaScript事件冒泡与取消事件冒泡代码演示

    本段代码演示了如何使用JavaScript取消HTML事件的冒泡,即当后代元素的事件被触发时,祖先元素的相同事件也会被触发。代码中,页面包含一个div元素和一个嵌套在其中的span元素,分别设置了单击响应函数。当单击span...

Global site tag (gtag.js) - Google Analytics