一、注册事件的三种方式

1 on的方式

语法:

事件源.on+事件名称 = 事件处理程序

例如:

btn.onclick = function(){}

细节:

只能注册一个事件处理函数

兼容:

所有主流浏览器都兼容

2   addEventListener

语法:

事件源.addEventListener(事件名称,事件处理程序,在哪个阶段执行)

例如:

btn.addEventListener(“click”,function (){},false)

细节:

事件名称不能带有on

可以为事件绑定多个处理程序

在事件处理函数中,this是对应的事件源

兼容:

ie8不支持

3   attachEvent

语法:

事件源.attachEvent(on+事件名称,事件处理程序)

例如:

btn.attachEvent(“onclick”,function(){})

细节:

也可以注册多个事件

注册的事件要带上on

在事件处理函数中,this是window

兼容

ie6到ie10支持,其余都不支持

4   注册事件的兼容写法

原理:

判断当前浏览器支持谁,支持哪个就用哪个来注册

function addListener(element,event,fn){

if (element.attachEvent){

element.attachEvent(“on”+event,fn)

}else if(element.addEventListener) {

element.addEventListener(event,fn,false)

}else {

element["on"+event] = fn;

}

}

二、移除事件绑定的处理程序

1 on的方式

方法:

事件源.on+事件名 = null;

2   removeEventListener

语法:

事件源.removeEventListener(事件名,处理程序,在哪个阶段)

例子:

btn.removeEventListener(“click”,clickHandel,false)

细节:

如果你在不同的阶段分别绑定了两个函数,要分开移除

移除的是使用addEventListener绑定的处理程序

兼容:

ie8不支持

3   detachEvent

语法:

事件源.detachEvent(on+事件名,处理程序)

例子:

btn.detachEvent(“onclick”,clickHandle)

细节:

移除的是使用attachEvent绑定的处理程序

兼容:

ie6-ie10支持,其余不支持

三、事件的三个阶段

事件的三个阶段分为:事件捕获阶段、事件目标阶段、事件冒泡阶段

要知道事件的阶段,需要通过一个属性: event.eventPhase

当eventPhase的值为1的时候,是事件捕获阶段,为2的时候是事件的目标阶段,为3的时候是冒泡阶段

事件在出现的时候

只会包含两个阶段:

a)    捕获和目标

b)    冒泡和目标

冒泡和捕获不会同时出现

三个阶段的异同:

事件在触发的时候,是有一个过程的

事件冒泡:后代元素触发某一个类型的事件,同时这个元素会传递到前代元素,并且触发前代元素的同类事件

事件捕获:发生某种类型的事件的时候,先有捕获的过程,先从前代元素递到触发事件的事件源子元素

事件目标阶段:事件触发到达事件源的时候

阻止冒泡

StopPropagation();//IE8不支持

CancelBubble=true;

On+eventType  相应的解绑方式:事件源.eventType=null;

AddEventListener  相应的解绑方式:事件源.removeEventListener(type,已经绑定的处理程序的函数名,对应的阶段);

以匿名函数的时候绑定的,是无法解绑的

如果绑定的时候,执行处理程序的阶段不同(第三个参数的true和false不同),在解绑的时候,也必须使用相应的触发阶段才能成功解绑,简而言之,如果是绑定的时候是false,解绑的时候也必须是false

解绑的时候只会解绑相同的函数名,如果不同就不会解绑,同名的函数重复绑定无效

attachEvent   相应的解绑方式:事件源.detachEvent(“on”+type,对应的绑定的函数名);、如果是以匿名函数的方式,也是无法解绑

每次解绑,函数名必须相同,否则不会解绑

总结:是用什么方式绑定事件处理程序,就必须使用相应的解绑方式解绑

四、事件的类型

得知事件的类型也是通过事件的一个属性获得

event.type

得到的是不带on的事件名称

利用这个属性,我们可以实现给一个元素注册多个事件,却调用同一个函数

DOM冒泡事件的更多相关文章

  1. dom 冒泡事件

    <!doctype html> <html> <head> <meta charset="utf-8"> <style> ...

  2. 前端基本知识(一):W3C标准&&冒泡事件,捕获事件,W3C DOM对象模型,对比分析

    W3C标准是万维网联盟, 其他的可以参考万维网版本的更新内容 一.W3C标准 二.W3C DOM事件 三.冒泡事件 四.捕获事件 一.W3C标准 其实网页是由三分部组成:1.结构(structure) ...

  3. Dom捕捉事件和冒泡事件-原理与demo测试

    先参考一下百度百科对冒泡事件流的解释: ----------不喜欢读文字的同学,可以直接看下面demo,传递顺序简单明了! http://baike.baidu.com/link?url=kaeJHT ...

  4. w3c标准 dom对象 事件冒泡和事件捕获

    http://www.cnblogs.com/chengxs/p/6388779.html http://www.jb51.net/article/42492.htm W3C标准是什么? 1.表现(c ...

  5. 整理之DOM事件阶段、冒泡与捕获、事件委托、ie事件和dom模型事件、鼠标事件

    整理之DOM事件阶段 本文主要解决的问题: 事件流 DOM事件流的三个阶段 先理解流的概念 在现今的JavaScript中随处可见.比如说React中的单向数据流,Node中的流,又或是今天本文所讲的 ...

  6. jquery技巧之让任何组件都支持类似DOM的事件管理

    本文介绍一个jquery的小技巧,能让任意组件对象都能支持类似DOM的事件管理,也就是说除了派发事件,添加或删除事件监听器,还能支持事件冒泡,阻止事件默认行为等等.在jquery的帮助下,使用这个方法 ...

  7. JS:event对象下的target属性和取消冒泡事件

    1.target 通过获取DOM元素 var box = document.getElementById("box"); document.box.onclick = functi ...

  8. JQuery阻止冒泡事件on绑定中异常情况分析

    科普下事件冒泡以及默认行为,以下面例子举列子:     事件冒泡:当点击内部button元素时,会触发自身及外层 a的点击事件,这就是事件冒泡引起的.事件会随着 DOM 的层次结构依次向上传播. 事件 ...

  9. Js 冒泡事件阻止

    Js 冒泡事件阻止   1. 事件目标 现在,事件处理程序中的变量event保存着事件对象.而event.target属性保存着发生事件的目标元素.这个属性是DOM API中规定的,但是没有被所有浏览 ...

随机推荐

  1. php 使用imagettftext()函数出问题的原因

    <?php header('Content-type: image/png'); $im = imagecreatetruecolor(400, 300); //创建画布 $white = im ...

  2. html常见兼容性问题

    html常见兼容性问题? 1.双边距BUG float引起的  使用display 2.3像素问题 使用float引起的 使用dislpay:inline -3px 3.超链接hover 点击后失效 ...

  3. 【转】Spring AOP 实现原理与 CGLIB 应用

    AOP(Aspect Orient Programming),作为面向对象编程的一种补充,广泛应用于处理一些具有横切性质的系统级服务,如事务管理.安全检查.缓存.对象池管理等.AOP 实现的关键就在于 ...

  4. java 链表常见题目

    如何判断单链表是否存在环 方法一.穷举遍历方法一:首先从头节点开始,依次遍历单链表的每一个节点.每遍历到一个新节点,就从头节点重新遍历新节点之前的所有节点,用新节点ID和此节点之前所有节点ID依次作比 ...

  5. win8 内置管理员账号既能使用metro应用又能使用默认共享

    一.内置管理员账号打开METRO应用 1.按WIN+R 弹出运行框. 2.输入gpedit.msc点确定,打开本地组策略编辑器. 3.逐级选择"计算机配置","Windo ...

  6. 免杀加密 前4K程序

    #include "stdafx.h" #include<windows.h> void Decrypt4k(TCHAR *str) { HANDLE hFile = ...

  7. html当前文档的状态

    <script type="text/javascript"> document.onreadystatechange = loadingChange;//当页面加载状 ...

  8. sql临时表的优点

    1: 临时表来组织数据,更高效的查询速度. 2:临时表的操作不会写入日志文件:好处:提高了 临时表操作的速度:坏处: 数据一旦丢失,无法恢复. 3: 临时表只允许当前会话框进行访问,因此不会担心死锁 ...

  9. Windows 下c获取文件目录

    由于要插数据库,构建sql语句,需要文件名,在网上找了半天,无奈都是Linux下的专用函数,伤心,,还有那个下载URL ,还木搞好,就要走啦,心焦哇 #include<iostream> ...

  10. Spark机器学习2·准备数据(pyspark)

    准备环境 anaconda nano ~/.zshrc export PATH=$PATH:/anaconda/bin source ~/.zshrc echo $HOME echo $PATH ip ...