首页 > web前端 > js教程 > 正文

详解js中的绑定事件和解绑事件

零下一度
发布: 2017-04-28 09:48:25
原创
1737人浏览过

本篇文章主要介绍了js绑定事件和解绑事件的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

在js中绑定多个事件用到的是两个方法:attachEvent和addEventListener,但是这两个方法又存在差异性

attachEvent方法  只支持IE678,不兼容其他浏览器

addEventListener方法   兼容火狐谷歌,不兼容IE8及以下

addEventListener方法

1

2

3

4

5

6

7

8

p.addEventListener('click',fn);

 

p.addEventListener('click',fn2);

function fn(){ console.log("春雨绵绵"); }

 

function fn2(){

        console.log("到处潮湿");

      }

登录后复制

attachEvent方法

1

2

3

4

5

6

p.attachEvent('onclick',fn);

p.attachEvent('onclick',fn2);

function fn(){ console.log("春雨绵绵"); }

function fn2(){

        console.log("到处潮湿");

      }

登录后复制

注意点:attachEvent方法绑定的事件是带on的,addEventListener绑定的事件是不带on的

下面我写了一个兼容了IE和火狐谷歌的方法

1

2

3

4

5

6

7

8

var p=document.getElementsByTagName("p")[0];

      addEvent('click',p,fn)

      function addEvent(str,ele,fn){

        ele.attachEvent?ele.attachEvent('on'+str,fn):ele.addEventListener(str,fn);

      }

      function fn(){

        console.log("春雨绵绵");

      }

登录后复制

这样就完美的解决了兼容性的问题

有绑定事件的话,那就肯定有解绑事件,但是解绑事件和绑定事件一样,万恶的IE还是会搞特殊化

detachEvent方法  只支持IE678,不兼容其他浏览器

removeEventListener方法   兼容火狐谷歌,不兼容IE8及以下

detachEvent方法写法:

ele.detachEvent("onclick",fn);

removeEventListener的写法:

ele.removeEventListener("click",fn);

下面我写了一个兼容性的方法给大家参考,实现也是很简单

1

2

3

function remove(str,ele,fn){

        ele.detachEvent?ele.detachEvent("on"+str,fn):ele.removeEventListener(str,fn);

      }

登录后复制

注意点:不管是绑定事件attachEvent还是删除事件detachEvent都是要加on的,removeEventListenser和addEventListenser则不需要加on

以上就是详解js中的绑定事件和解绑事件的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号