zoukankan      html  css  js  c++  java
  • 事件冒泡 比bubble


    冒泡的概念就是 当子元素触发事件的时候 相应的祖宗十八代素也会触发相同的事件
    (前提父元素也添加了一样的事件)
    eg:儿子 有一个onclick 祖宗十八代 也有onclick
    当点击儿子的时候 祖宗十八代的点击事件也会被触发
    有时候这种情况会导致很多问题 所以要阻止冒泡
    只有被点击的元素才触发事件
    不是所有的事件都会冒泡
    onblur onfocus onload onerror 没有

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

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

    接下来上代码 很容易 做一个兼容处理就好了
    <!doctype html>
    <html lang="en">
     <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>
  • 相关阅读:
    随机生成字符串,可用来当id
    自己总结的关于uniapp项目用androidstuido打包成apk
    css3 滑动效果 门
    在数组里面随机获取随机的几个内容
    把一个数组分割成两个(不管奇数还是偶数)
    Mysql常用命令
    怎样才能彻底地删除多余输入法软件
    启动MySQL服务
    linux监控命令全覆盖
    浅谈MVC模式与SSH框架
  • 原文地址:https://www.cnblogs.com/liveoutfun/p/9306834.html
Copyright © 2011-2022 走看看