全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

addEventListener()与removeEventListener()解析

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); //有效!

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


# addEventListener  # removeEventListener  # JavaScript使用addEventListener添加事件监听用法实例  # addEventListener—jQuery的事件监听方法  # 移除  # 的是  # 所示  # 绑定  # 布尔值  # 是个  # 是因为  # 在这个  # 多个  # 要在  # 这也  # 要注意  # 第二个  # 重写  # 可以使用  # 介绍一下  # 这两种  # 要跟  # 中都  # 大家多多 


相关文章: 高端建站三要素:定制模板、企业官网与响应式设计优化  建站之星在线客服如何快速接入解答?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  建站主机与服务器功能差异如何区分?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  兔展官网 在线制作,怎样制作微信请帖?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  如何选择高性价比服务器搭建个人网站?  成都网站制作报价公司,成都工业用气开户费用?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  测试制作网站有哪些,测试性取向的权威测试或者网站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  已有域名如何快速搭建专属网站?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  Python如何创建带属性的XML节点  非常酷的网站设计制作软件,酷培ai教育官方网站?  图册素材网站设计制作软件,图册的导出方式有几种?  定制建站流程解析:需求评估与SEO优化功能开发指南  如何通过智能用户系统一键生成高效建站方案?  C#如何在一个XML文件中查找并替换文本内容  如何快速使用云服务器搭建个人网站?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何撰写建站申请书?关键要点有哪些?  如何在腾讯云服务器快速搭建个人网站?  独立制作一个网站多少钱,建立网站需要花多少钱?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  如何零基础开发自助建站系统?完整教程解析  javascript基本数据类型及类型检测常用方法小结  建站为何优先选择香港服务器?  如何在Windows虚拟主机上快速搭建网站?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  已有域名和空间,如何快速搭建网站?  建站之星后台管理如何实现高效配置?  如何使用Golang安装API文档生成工具_快速生成接口文档  音响网站制作视频教程,隆霸音响官方网站?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  定制建站策划方案_专业建站与网站建设方案一站式指南  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  婚礼视频制作网站,学习*后期制作的网站有哪些?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  建站之星后台管理系统如何操作?  网站建设设计制作营销公司南阳,如何策划设计和建设网站?  建站之星代理平台如何选择最佳方案?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  如何制作算命网站,怎么注册算命网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。