#javascript# DOM2
栏目: JavaScript · 发布时间: 5年前
内容简介:2.DOM2中可以给当前元素的某一个事件行为绑定多个不同的方法(因为绑定的所有方法都存放在事件池中)
DOM2事件绑定的原理
1.DOM2事件绑定使用的addEventListener/attachEvent都是在EventTarget这个内置类的原型上定义的,我们使用的时候,会通过原型链找个这个方法,然后执行绑定的事件。
2.浏览器会给当前元素的某一个事件行为开辟一个事件池(事件队列),准确来说,浏览器有一个统一的事件池,我们给每个元素绑定的某个方法都会放在这个事件池中,然后通过相关的标识来进行区分。当我们通过addEventListener/attachEvent做事件监听的时候,会把绑定的方法存放在事件池中。
3.当元素的某一个行为被触发,浏览器会把当前存放在事件池中的所有方法,依次按照存放的先后顺序执行。
DOM2特点
- 所有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)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Design and Analysis of Distributed Algorithms (Wiley Series on P
Nicola Santoro / Wiley-Interscience / 2006-10-27 / USD 140.95
This text is based on a simple and fully reactive computational model that allows for intuitive comprehension and logical designs. The principles and techniques presented can be applied to any distrib......一起来看看 《Design and Analysis of Distributed Algorithms (Wiley Series on P》 这本书的介绍吧!