#javascript# DOM2

栏目: JavaScript · 发布时间: 7年前

内容简介:2.DOM2中可以给当前元素的某一个事件行为绑定多个不同的方法(因为绑定的所有方法都存放在事件池中)
DOM2事件绑定的原理

1.DOM2事件绑定使用的addEventListener/attachEvent都是在EventTarget这个内置类的原型上定义的,我们使用的时候,会通过原型链找个这个方法,然后执行绑定的事件。

2.浏览器会给当前元素的某一个事件行为开辟一个事件池(事件队列),准确来说,浏览器有一个统一的事件池,我们给每个元素绑定的某个方法都会放在这个事件池中,然后通过相关的标识来进行区分。当我们通过addEventListener/attachEvent做事件监听的时候,会把绑定的方法存放在事件池中。

3.当元素的某一个行为被触发,浏览器会把当前存放在事件池中的所有方法,依次按照存放的先后顺序执行。

DOM2特点

  1. 所有DOM0支持的事件行为DOM2都可以使用,而且DOM2还支持一些DOM0没有的事件行为:DOMContentLoaded
//DOM0下没有这个属性:
document.body.DOMContentLoaded === undefined

//DOM2标准浏览器下:
document.body.addEventListener('DOMContentLoaded',function(){
    //标准浏览器中兼容这个事件,当浏览器中的DOM结构加载完成,就会触发这个事件(也会把绑定的方法执行)
},false)

//DOM2下IE6~8下也不支持这个事件
document.body.attachEvent('onDOMContentLoaded',function(){
})

2.DOM2中可以给当前元素的某一个事件行为绑定多个不同的方法(因为绑定的所有方法都存放在事件池中)

function fn1(){
console.log('1');
}

function fn2(){
console.log('2');
}

function fn3(){
console.log('3');
}

document.body.addEventListener('click', fn1, false);
document.body.addEventListener('click', fn3, false);
document.body.addEventListener('click', fn2, false);

//fn2事件移除。移除的时候要求   事件类型、绑定的方法、传播阶段三个完全一致才可以移除掉

document.body.removeEventListener('click', fn2, false)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

伟大创意的诞生

伟大创意的诞生

史蒂文·约翰逊 (Steven Johnson) / 盛杨燕 / 浙江人民出版社 / 2014-8-1 / CNY 52.90

 大家都认得出好创意。印刷机、铅笔、抽水马桶、电池、互联网、GPS、Google——这些都是绝妙的创意。然而,它们是如何产生的?被喻为“科技界的达尔文”的作者,在《伟大创意的诞生》一书中,提供了深具启示意义以及有论证实据的答案。  作者史蒂文•约翰逊以富有感染力、包罗万象的风格游历于多重领域,从神经生物学、都市研究,到网络文化,找出了独特创新背后的7大关键模式,深入人类600年重要发明的......一起来看看 《伟大创意的诞生》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具