事件绑定、事件冒泡与捕获

一、事件绑定
事件绑定又称事件委托,事件代理,可以给同一个div绑定多个事件

非IE:

    element.addEventListener("click",fn,false) 事件绑定
    element.removeEventLisenter("click",fn,false) 解除绑定

IE:

    element.attachEvent("onclick",fn) 事件绑定
    element.detachEvent("onclick",fn) 解除绑定

绑定事件兼容写法:(移除同理)

function addEvent(element,type,fn){
     if(element.addEventListener){
            element.addEventListener(type,fn,false)
     }else if(element.attachEvent){
            element.attachEvent("on"+type,fn);
     }else{
            target["on"+type]=fn;
     }
}

二、js事件捕获和冒泡

1.什么是事件冒泡:
事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。(默认的事件处理程序,从子级到父级)

2.什么是事件捕获:
事件从最不精确的对象(document 对象)开始触发,然后到最精确(也可以在窗口级别捕获事件,不过必须由开发人员特别指定)。(捕获型事件先发生,由父级到子级)

3.事件绑定中的false,true
(1)作用:第3个参数useCapture是一个Boolean值,用来设置事件是在事件捕获时执行,还是事件冒泡时执行
(2)true:事件捕获,父级元素先触发,子级元素后触发,即div先触发,p后触发
(3)false:事件冒泡,子级元素先触发,父级元素后触发,即p先触发,div后触发。

4.阻止冒泡:
ev.cancelBubble=true;
ev.stopPropagation();

5.阻止冒泡的兼容写法:

function stopBubble(e){
        if(e&&ev.stopPropagation){
              e.stopPropagation();
        }else{
            e.cancelBubble=true;
        }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景知识 什么是事件?直观的说就是网页上发生的事情,大部分是指用户的鼠标动作和键盘动作,如点击、移动鼠标、按下某个...
    吧啦啦小汤圆阅读 1,894评论 2 15
  • 一、DOM 什么是DOM?Document Object Model(文档对象模型)。DOM是针对HTML和XML...
    空谷悠阅读 990评论 0 2
  • 这几天我一直在思考如何写好一篇文章。发愁的初衷是参加了一个坚持30天写作的一个班,无主题无限制,保证500字...
    迎凤斩月阅读 192评论 0 0
  • 有时候真的特别想谈恋爱,特别特别特别想。想依偎想拥抱想亲密接触想相视一笑想手拉手想很多很多。发疯的想。我想我是完了...
    withoutyou阅读 111评论 0 0
  • 用我三生烟火,换你一世迷离。听弦断,断那三千痴缠。坠花湮,湮没一朝风涟。花若怜,落在谁的指尖。 ​​​
    浅_夜阅读 168评论 0 1