addEventListener和attachEvent以及element.onclick的区别
Posted waisonlong
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了addEventListener和attachEvent以及element.onclick的区别相关的知识,希望对你有一定的参考价值。
attachEvent是ie添加事件处理程序,接收两个参数,其中事件类型名称要加"on",
可以添加多个事件处理程序,按照添加顺序相反的顺序触发;
addEventListener是给非ie添加事件处理程序,接收三个参数,第一个是事件名,不需要加“on”,
第二个是绑定的函数,第三个参数是一个布尔值,是事件的方式,意思是是否使用useCatch方式,
如果是false,就使用传统的冒泡方式,如果为true,就在捕获阶段调用事件处理程序。
addEventListener可以添加多个事件处理程序,按照添加顺序触发
二者有个本质上的区别,attachEvent的事件处理程序会在全局作用域中运行,this等于window对象,
而addEventLinstener添加的事件处理程序是在其依附的元素的作用域中运行的,this等于绑定元素对象。
既然他们的this指向不同,那怎么才能实现相同的this指向呢?
如果想要实现this关键字指向相同的话,要用Function的apply或者call方法。示例代码如下:
function bind(el, fn, type){ var _fn = function(){ fn.apply(el, arguments); }; window.addEventListener ? el.addEventListener(type, _fn, false) : el.attachEvent("on" + type, _fn); }
即用el来代替_fn里的this。(方法待测试)
测试代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>addEventListener和attachEvent测试</title> </head> <body> <input type="button" value="test" id="btn_test"> </body> <script> var btn_test = document.getElementById(\'btn_test\'); function attachEvt(obj,ev,fn){ if(obj.attachEvent){ obj.attachEvent(\'on\'+ev,fn); }else{ obj.addEventListener(ev,fn,false); } } attachEvt(btn_test,\'click\',function(){ alert(this); }) </script> </html>
ff弹出如图:
ie弹出如图:
本质的区别是el.onclick相当于在标签上写onclick,用addEventListener和attachEvent是通过DOM接口去绑定事件。
el.onclick=function(event){ alert(event.type); //"click" }; el.addEventListener("click",function(event){ alert(el.type); //"click" },false);
通过HTML标签属性指定的事件处理程序时,变量event中保存着event对象。
<input type="button" value="Click me" onclick="alert(event.type)"/> //"click"
el.onclick=function(){ var event=window.event; alert(event.type); //"click" }
如果通过attachEvent()添加事件处理程序时,event对象作为参数被传入事件处理程序,
el.attachEvent("onclick",function(event){ alert(event.type); //"click" });
以上是关于addEventListener和attachEvent以及element.onclick的区别的主要内容,如果未能解决你的问题,请参考以下文章
addEventListener和attachEvent的区别(转载)
JavaScript中的attachEvent和addEventListener
js 添加事件 attachEvent 和 addEventListener