当前位置: 移动技术网 > IT编程>开发语言>JavaScript > addEventListener()与removeEventListener()解析

addEventListener()与removeEventListener()解析

2018年05月20日  | 移动技术网IT编程  | 我要评论

addeventlistener()与removeeventlistener()用于处理指定和删除事件处理程序操作。
所有的dom节点中都包含这两种方法,并且它们都接受3个参数:要处理的事件名、作为事件处理程序的函数和一个布尔值。

最后这个布尔值参数是true,表示在捕获阶段调用事件处理程序;
如果是false(false- 默认),表示在冒泡阶段调用事件处理程序。

addeventlistener的参数一共有三个,语法为:
element.addeventlistener(type,listener,usecapture)

下面是详解:
1、其中element是要绑定函数的对象。
2、type是事件名称,要注意的是"onclick"要改为"click","onblur"要改为"blur",也就是说事件名不要带"on"。
3、listener当然就是绑定的函数了,记住不要跟括号
4、最后一个参数是个布尔值,表示该事件的响应顺序,下面重点介绍一下addeventlistener的第3个参数(usecapture)。

要在按钮上为click事件添加事件处理程序,可以使用下列代码:

var btn = document.getelementbyid("mybtn");
btn.addeventlistener("click", function () {
  alert(this.id);
}, false);    

使用dom2级方法添加事件处理程序的主要好处是可以添加多个事件处理程序。来看下面的例子:

var btn = document.getelementbyid("mybtn");

btn.addeventlistener("click", function () {
  alert(this.id);
}, false);  
btn.addeventlistener("click", function () {
  alert("hello world");
}, false);

通过addeventlistener()添加的事件处理程序只能使用removeeventlistener()来移除;

移除时传入的参数与添加处理程序时使用的参数相同。
这也意味着通过addeventlistener()添加的匿名函数无法移除,如下面的例子所示:

var btn = document.getelementbyid("mybtn");

btn.addeventlistener("click", function () {
   alert(this.id);
}, false);
btn.removeeventlistener("click", function () { //无效!
   alert(this.id);
}, false);

在这个例子中,我使用addeventlistener()添加一个事件处理程序。
虽然调用removeeventlistener看似使用了相同的参数
但实际上,第二个参数与传入addeventlistener()中的是完全不同的函数。
而传入removeeventlistener()中的事件处理程序函数必须与传入addeventlistener()中的相同,

下面的例子所示:

var btn = document.getelementbyid("mybtn");
var handler = function () {
   alert(this.id);
};
btn.addeventlistener("click", handler, false);
btn.removeeventlistener("click", handler, false); //有效! 

重写后的这个例子没有问题,是因为在addeventlistener()和removeeventlistener()中用来相同的函数。
实验结果是,用户点击button时,每次都会输出"i have been clicked!",说明removeeventlistener()函数没有起到作用。 

通过查找资料,得出结论。在使用removeeventlistener()函数时,handler函数,必须和使用addeventlistener()里面的handler函数必须相同。

所以上面写的代码是错误的。修正之后的代码应该如下:

//addeventlistener()和removeeventlistener()中handler函数必须相同,移除事件函数才有效。
function myhandler(){
  console.log("i have been clicked!");
  document.getelementbyid('info').removeeventlistener('click',myhandler,false);
}
var target=document.getelementbyid('info');
target.addeventlistener("click", myhandler, false);
target.removeeventlistener("click", myhandler, false); //有效!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网