addEventListener()与removeEventListener()的区别是什么

  介绍

addEventListener()与removeEventListener()的区别是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

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

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

addEventListener的参数一共有三个,语法为:
element.addEventListener(类型、监听器、useCapture)

下面是详解:
1,其中元素是要绑定函数的对象。
2,类型是事件名称,要注意的是“onclick"要改为“click",“onblur"要改为“blur",也就是说事件名不要带“知道;。
3,侦听器当然就是绑定的函数了,记住不要跟括号
4,最后一个参数是个布尔值,表示该事件的响应顺序、下面重点介绍一下addEventListener的第3个参数(useCapture)。

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

var  btn =, . getelementbyid (“myBtn");   btn.addEventListener (“click", function  (), {   警报才能(this.id);   },,假);

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

var  btn =, . getelementbyid (“myBtn");      btn.addEventListener (“click", function  (), {   警报才能(this.id);   },,假),,,   btn.addEventListener (“click", function  (), {   警报才能(“Hello  World");   },,假);

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

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

var  btn =, . getelementbyid (“myBtn");      btn.addEventListener (“click", function  (), {   ,,警报(this.id);   },,假);   btn.removeEventListener (“click", function (),{,//无效!   ,,警报(this.id);   },,假);

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

下面的例子所示:

var  btn =, . getelementbyid (“myBtn");   var  handler =, function  (), {   ,,警报(this.id);   };   btn.addEventListener (“click",处理程序,,假);   btn.removeEventListener (“click",处理程序,,假),,//有效!

重写后的这个例子没有问题,是因为在addEventListener()和removeEventListener()中用来相同的函数。
实验结果是,用户点击按钮时,每次都会输出“我已经点击!“,说明removeEventListener()函数没有起到作用只

通过查找资料,得出结论。在使用removeEventListener()函数时,处理程序函数,必须和使用addEventListener()里面函的处理器数必须相同。

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

//addEventListener()和removeEventListener()中处理函数必须相同,移除事件函数才有效。   function  myhandler () {   console.log才能(“小姐:have  been 点击!“);   ,,. getelementbyid(& # 39;信息# 39;).removeEventListener(& # 39;点击# 39;,myhandler,假);   }   var 目标=. getelementbyid(& # 39;信息# 39;);   target.addEventListener (“click", myhandler,,假);   target.removeEventListener (“click", myhandler,,假),,//有效!

看完上述内容,你们掌握addEventListener()与removeEventListener()的区别是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!

addEventListener()与removeEventListener()的区别是什么