1、DOM0事件与DOM2级在事件监听使用方式上有声明区别?
- DOM0事件添加形式
var btn = document.getElementById('btn');
btn.onclick = function(){
console.log(this); //btn, this指向元素本身
}
DOM0中事件处理程序是该元素的一个方法,局限在于只能存在一个处理程序,若再次向同一元素添加另一个处理程序,则上一个会被覆盖;事件通常以'on'开头,如onmouseover,onmouseout等。DOM0的优势在于简单和兼容性好
- DOM2级事件监听使用的方法
var btn = document.getElementById('btn');
btn.addEventListener('type',function(){
console.log(this); //btn,this指向元素本身
})
DOM2事件中定义了两个方法,即addEventListener()/removeEventListener(),用于处理指定和删除事件处理程序的操作,所有的DOM节点都包含这两个方法,并可接受三个参数:1、事件类型 2、事件处理方法 3、布尔(true表示捕获阶段调用事件处理程序,false表示冒泡阶段事件处理;默认为false)
DOM2的优势在于可以添加多个事件处理程序。
2、attachEvent与addEventListener的区别?
- attachEvent()是IE的事件处理程序,
- addEventListener()是标准的事件处理程序
区别:
1、事件名:attachEvent的事件名与DOM0级的事件名一样,都需要在具体事件type(如click)前加'on',而addEventListener()不用。
2、作用域:在attachEvent的事件处理程序中,它的作用域是全局作用域,this指向window; 而在addEventListener里事件处理程序的作用域是元素的作用域,this等于元素本身。
3、参数:addEventListener有三个参数,attachEvent只有两个参数。在于attachEvent添加的事件处理程序只能发生在冒泡阶段,addEventListener第三个参数可以决定添加的事件处理程序是在捕获阶段还是冒泡阶段处理(我们一般为了浏览器兼容性都设置为冒泡阶段)
4、为一个事件添加多个事件处理程序时,执行顺序不同: addEventListener添加会按照添加顺序执行;而attachEvent添加多个事件处理程序时顺序无规律(添加的方法少的时候大多是按添加顺序的反顺序执行的,但是添加的多了就无规律了),所以添加多个的时候,不依赖执行顺序的还好,若是依赖于函数执行顺序,最好自己处理,不要指望浏览器
3、解释IE事件冒泡和DOM2事件传播机制?
- IE冒泡:事件开始时由最具体的元素接收,事件从目标元素开始向父级传递,直到window(document)停止。
- DOM2事件:DOM2级事件规定事件流包括三个阶段,事件捕获阶段,处于目标阶段,事件冒泡阶段,首先发生的是事件捕获,为截取事件提供机会,然后是实际目标接收事件,最后是冒泡阶段。
4、如何阻止事件冒泡? 如何阻止默认事件?
标准浏览器:
在事件的对象中添加stopPropagation()这个方法可阻止事件冒泡;preventDefault()这个方法可阻止事件默认行为IE浏览器:
在事件对象中设置cancelBubble = true可阻止事件冒泡;设置returnValue = true可阻止事件默认行为