JavaScript   发布时间:2022-04-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了addEventListener()与removeEventListener()解析大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

addEventListener的参数一共有三个,语法为: E)

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

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

); btn.addEventListener("click",function () { alert(this.id); },falsE);

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

);

btn.addEventListener("click",falsE);
btn.addEventListener("click",function () {
alert("Hello World");
},falsE);

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

移除时传入的参数与添加处理程序时使用的参数相同。 这也意味着通过addEventListener()添加的

匿名函数无法移除

如下面的例子所示:

);

btn.addEventListener("click",function () {
alert(this.id);
},falsE);
btn.removeEventListener("click",function () { //无效!
alert(this.id);
},falsE);

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

下面的例子所示:

); var handler = function () { alert(this.id); }; btn.addEventListener("click",handler,falsE); //有效!

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

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

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

{ console.log("I have been clicked!"); document.getElementById('info').removeEventListener('click',myhandler,falsE); } var target=document.getElementById('info'); target.addEventListener("click",falsE); target.removeEventListener("click",falsE); //有效!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持菜鸟教程。

大佬总结

以上是大佬教程为你收集整理的addEventListener()与removeEventListener()解析全部内容,希望文章能够帮你解决addEventListener()与removeEventListener()解析所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。