JS添加事件和解绑事件:addEventListener()与removeEventListener()
2024-08-30 11:10:25
作用:
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);
总结:
一:相同事件绑定和解除,需要使用共用函数;
二:共用函数不能带参数;
最新文章
- 步入angularjs directive(指令)--准备工作熟悉hasOwnProperty
- emoji哈哈哈哈
- Android Studio no debuggable applications解决方案2
- Cocos2d-x数据持久化-修改数据
- 1080. Graduate Admission (30)
- lua协程实现简析
- 微信企业号 出现redirect_uri unauthorized 50001 解决办法
- 07.15 first与first-child的区别
- 基于QtQuick2.0应用程序运行于XP系统的诸多问题
- asp.net访问网络路径方法(模拟用户登录)
- SharePoint 2013 如何使用Silverlight
- crawler_基础之_java.net.HttpURLConnection 访问网络资源
- 关于SQL经典题
- Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包
- 面向对象设计的SOLID原则、迪米特法则
- vue2.0 axios交互
- Cannot find a valid baseurl for repo: base/7/x86_64
- iOS 第三方框架-MJRefresh
- 让图片在div中居中
- Unity编辑器 - Undo的坑