首页  >  文章  >  web前端  >  对事件的冒泡比bubble的代码分析

对事件的冒泡比bubble的代码分析

不言
不言原创
2018-07-14 16:06:572269浏览

这篇文章主要介绍了关于对事件冒泡比bubble的代码分析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

冒泡的概念就是  当子元素触发事件的时候  相应的祖宗十八代素也会触发相同的事件

(前提父元素也添加了一样的事件)

eg:儿子 有一个onclick  祖宗十八代 也有onclick

   当点击儿子的时候  祖宗十八代的点击事件也会被触发

   有时候这种情况会导致很多问题  所以要阻止冒泡

   只有被点击的元素才触发事件

   不是所有的事件都会冒泡

   onblur onfocus  onload  onerror 没有

  其实事件的触发一共有三个过程 : 捕获阶段--->处于目标阶段---->冒泡阶段

  标准浏览器冒泡顺序 子元素-->父辈-->body-->document--->window

  IE 子元素-->父辈-->body-->document

  接下来上代码  很容易  做一个兼容处理就好了

<!doctype html>
<html>
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>阻止冒泡</title>
 </head>
 <body>
     <input type="button"  id="cancelBubble" value="取消冒泡"/>
    <script type="text/javascript">
          var btn=document.getElementById("cancelBubble");
          document.onclick=function(){
            alert("冒泡");
          }
          btn.onclick=function(event){
          var event=event||window.event;//兼容
          if(event && event.stopPropagation){
               
               event.stopPropagation();
          
          }
          else{
              //IE 678
             event.cancelBubble=true;
          }
           alert("没有冒泡");
          
          }
    </script>
 </body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

对于NodeJS如何操作消息队列RabbitMQ的分析

 JavaScript如何实现文件的下载功能

以上是对事件的冒泡比bubble的代码分析的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn