共计 1037 个字符,预计需要花费 3 分钟才能阅读完成。
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)
正文完
发表至: javascript
2019-05-18