#javascript# DOM2

DOM2事件绑定的原理
1.DOM2事件绑定使用的addEventListener/attachEvent都是在EventTarget这个内置类的原型上定义的,咱们使用的时候,会经过原型链找个这个方法,而后执行绑定的事件。
2.浏览器会给当前元素的某一个事件行为开辟一个事件池(事件队列),准确来讲,浏览器有一个统一的事件池,咱们给每一个元素绑定的某个方法都会放在这个事件池中,而后经过相关的标识来进行区分。当咱们经过addEventListener/attachEvent作事件监听的时候,会把绑定的方法存放在事件池中。
3.当元素的某一个行为被触发,浏览器会把当前存放在事件池中的全部方法,依次按照存放的前后顺序执行。浏览器

DOM2特色code

  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)

DOM0和DOM2执行顺序的问题队列

function fn(){
console.log(1);
}

document.addEventListerner('click', fn, false);
document.addEventListerner('click', fn, false);//第二次存储不到事件池中,由于事件池中已经存在fn。  到这里只会输出 1
document.onclick = fn;//会输出  1  1
document.onclick = function() {
    console.log(2);
}
document.addEventListerner('click', function(){
console.log(3);
}, false);
//输出结果 1 2 3
// 1. DOM0和DOM2绑定的方法是毫无关系的(由于他们是两套不一样的处理机制),即便绑定的方法相同,也是执行2次
//2. 谁先绑定,就先执行谁。

DOM0:浏览器会把一些经常使用的事件挂载到元素对象的私有属性上。让咱们能够实现DOM0事件绑定
DOM2:凡是浏览器给元素天生设置的事件在DOM2中均可以用事件

相关文章
相关标签/搜索