作用:

addEventListener()与removeEventListener()用于处理指定和删除事件处理程序操作。

它们都接受3个参数:事件名、事件处理的函数和布尔值。

布尔值参数是true,表示在捕获阶段调用事件处理程序;如果是false,表示在冒泡阶段调用事件处理程序。

示例:

环境:移动端,界面禁止触摸事件

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

document.body.addEventListener('touchmove', function (event) {
event.preventDefault();
},false);

通过addEventListener()添加的事件处理程序只能使用removeEventListener()来移除;移除时传入的参数与添加处理程序时使用的参数相同。这也

意味着通过addEventListener()添加的匿名函数无法移除

错误用法示例:

document.body.addEventListener('touchmove', function (event) {
event.preventDefault();
},false);
document.body.removeEventListener('touchmove', function (event) {
event.preventDefault();
},false);

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

正确用法示例:

function bodyScroll(event){
event.preventDefault();
}
document.body.addEventListener('touchmove',bodyScroll,false);
document.body.removeEventListener('touchmove',bodyScroll,false);

重写后的这个例子没有问题,是因为在addEventListener()和removeEventListener()中用来相同的函数。

共用函数不能带参数,错误用法示例:

function bodyScroll(event){
event.preventDefault();
}
document.body.addEventListener('touchmove',bodyScroll(event),false);
document.body.removeEventListener('touchmove',bodyScroll(event),false);

总结:

一:相同事件绑定和解除,需要使用共用函数;

二:共用函数不能带参数;

最新文章

  1. 步入angularjs directive(指令)--准备工作熟悉hasOwnProperty
  2. emoji哈哈哈哈
  3. Android Studio no debuggable applications解决方案2
  4. Cocos2d-x数据持久化-修改数据
  5. 1080. Graduate Admission (30)
  6. lua协程实现简析
  7. 微信企业号 出现redirect_uri unauthorized 50001 解决办法
  8. 07.15 first与first-child的区别
  9. 基于QtQuick2.0应用程序运行于XP系统的诸多问题
  10. asp.net访问网络路径方法(模拟用户登录)
  11. SharePoint 2013 如何使用Silverlight
  12. crawler_基础之_java.net.HttpURLConnection 访问网络资源
  13. 关于SQL经典题
  14. Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
  15. 面向对象设计的SOLID原则、迪米特法则
  16. vue2.0 axios交互
  17. Cannot find a valid baseurl for repo: base/7/x86_64
  18. iOS 第三方框架-MJRefresh
  19. 让图片在div中居中
  20. Unity编辑器 - Undo的坑

热门文章

  1. table内 获取同一行 其他列的value
  2. 关闭页面,window.onunload事件未执行的原因
  3. 内存泄漏分析工具tMemMonitor (TMM)使用简介
  4. app基础
  5. MTK UART串口调试
  6. es6 import 报错
  7. node process-进程
  8. ZipHelper
  9. c# aop讲解
  10. 电商:html样式集合