美文网首页
事件绑定、事件冒泡与捕获

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

作者: 云淡风轻_301b | 来源:发表于2017-10-24 21:55 被阅读0次

一、事件绑定
事件绑定又称事件委托,事件代理,可以给同一个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;
        }
}

相关文章

  • 事件

    事件顺序 先执行捕获事件,然后目标阶段,再执行冒泡事件 给一个dom即绑定了捕获,又绑定了冒泡,那么先绑定什么事件...

  • 原始类型与事情委托

    1.绑定事件: 二、事件冒泡与事件捕获 事件委托 案例见事件委托 计时器

  • Javascript事件系统

    本文内容 事件基础 事件监听方式 事件默认行为 事件冒泡与事件捕获 事件绑定与事件委托 事件基础 注意:本文不会深...

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

    一、事件绑定事件绑定又称事件委托,事件代理,可以给同一个div绑定多个事件 非IE: IE: 绑定事件兼容写法:(...

  • Javascript事件系统

    本文内容:事件基础事件监听方式事件默认行为事件冒泡与事件捕获事件绑定与事件委托事件基础注意:本文不会深入探究Jav...

  • 事件生僻知识学习笔记

    DOM2 级事件包括: 事件捕获,处于目标,事件冒泡 绑定事件方法: HTML上直接绑定 DOM0级事件处理程序 ...

  • 微信小程序中bind和catch的区别

    bindtap 冒泡事件,事件绑定不会阻止冒泡事件向上冒泡catchtap 非冒泡事件, 事件绑定阻止冒泡事件...

  • 我的前端入门笔记(11)--事件冒泡、捕获、代理

    1.事件冒泡与捕获 冒泡:先触发内部事件,再触发外部事件;捕获:先触发外部事件,再触发内部事件; addEvent...

  • js运用

    1.属性操作 2.BOM操作 3.计时事件 4.事件绑定 事件冒泡和事件捕获

  • 事件绑定&事件冒泡与捕获

    大家在做笔试题的时候肯定经常会遇到事件绑定和事件冒泡与捕获的问题,这篇我们来详细解析 JavaScript 的事件...

网友评论

      本文标题:事件绑定、事件冒泡与捕获

      本文链接:https://www.haomeiwen.com/subject/rtgiuxtx.html