js绑定事件和解绑事件


Posted in Javascript onApril 27, 2017

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

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

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

addEventListener方法

div.addEventListener('click',fn);

div.addEventListener('click',fn2);
function fn(){ console.log("春雨绵绵"); }

function fn2(){
        console.log("到处潮湿");
      }

attachEvent方法

div.attachEvent('onclick',fn);
div.attachEvent('onclick',fn2);
function fn(){ console.log("春雨绵绵"); }
function fn2(){
        console.log("到处潮湿");
      }

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

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

var div=document.getElementsByTagName("div")[0];
      addEvent('click',div,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);

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

function remove(str,ele,fn){
        ele.detachEvent?ele.detachEvent("on"+str,fn):ele.removeEventListener(str,fn);
      }

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

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木

Javascript 相关文章推荐
jquery选择器-根据多个属性选择示例代码
Oct 21 Javascript
使用npm发布Node.JS程序包教程
Mar 02 Javascript
jquery模拟进度条实现方法
Aug 03 Javascript
PHP抓取HTTPS内容和错误处理的方法
Sep 30 Javascript
JavaScript 九种跨域方式实现原理
Feb 11 Javascript
vue列表单项展开收缩功能之this.$refs的详解
May 05 Javascript
WebSocket的简单介绍及应用
May 23 Javascript
Vue 基于 vuedraggable 实现选中、拖拽、排序效果
May 18 Javascript
Vue项目中数据的深度监听或对象属性的监听实例
Jul 17 Javascript
Vue-CLI 3 scp2自动部署项目至服务器的方法
Jul 24 Javascript
javascript实现打砖块小游戏(附完整源码)
Sep 18 Javascript
关于vue 项目中浏览器跨域的配置问题
Nov 10 Javascript
详解ECMAScript6入门--Class对象
Apr 27 #Javascript
利用Vue v-model实现一个自定义的表单组件
Apr 27 #Javascript
详解Vue 普通对象数据更新与 file 对象数据更新
Apr 26 #Javascript
微信小程序实现给循环列表添加点击样式实例
Apr 26 #Javascript
微信小程序 request接口的封装实例代码
Apr 26 #Javascript
微信小程序中hidden不生效原因的解决办法
Apr 26 #Javascript
微信小程序 flex实现导航实例详解
Apr 26 #Javascript
You might like
Laravel框架学习笔记(一)环境搭建
2014/10/15 PHP
优化WordPress的Google字体以加速国内服务器上的运行
2015/11/24 PHP
Jquery图形报表插件 jqplot简介及参数详解
2012/10/10 Javascript
为Javascript中的String对象添加去除左右空格的方法(示例代码)
2013/11/30 Javascript
使用jQuery获取data-的自定义属性
2015/11/10 Javascript
深入浅析JavaScript系列(13):This? Yes,this!
2016/01/05 Javascript
什么是Vue.js框架 为什么选择它?
2017/10/17 Javascript
使用Bootstrap和Vue实现用户信息的编辑删除功能
2017/10/25 Javascript
Vue的elementUI实现自定义主题方法
2018/02/23 Javascript
node.js之基础加密算法模块crypto详解
2018/09/11 Javascript
深入解析ES6中的promise
2018/11/08 Javascript
webpack项目使用eslint建立代码规范实现
2019/05/16 Javascript
使用js在layui中实现上传图片压缩
2019/06/18 Javascript
6种JavaScript继承方式及优缺点(小结)
2020/02/06 Javascript
Python实现多线程下载文件的代码实例
2014/06/01 Python
Django发送html邮件的方法
2015/05/26 Python
Python2.7简单连接与操作MySQL的方法
2016/04/27 Python
使用Python的Turtle库绘制森林的实例
2019/12/18 Python
浅谈Pycharm的项目文件名是红色的原因及解决方式
2020/06/01 Python
基于python+selenium自动健康打卡的实现代码
2021/01/13 Python
全球酒店预订网站:Hotels.com
2016/08/10 全球购物
C++:局部变量能否和全局变量重名
2014/03/03 面试题
同步和异步有何异同,在什么情况下分别使用他们
2013/04/09 面试题
大学生四个方面的自我评价
2013/09/19 职场文书
预备党员党校学习自我评价分享
2013/11/12 职场文书
索桥的故事教学反思
2014/02/06 职场文书
2014年最新党员对照检查材料汇总
2014/09/15 职场文书
债务授权委托书范本
2014/10/17 职场文书
土地租赁协议书
2015/01/29 职场文书
员工试用期转正自我评价
2015/03/10 职场文书
实习护士自荐信
2015/03/25 职场文书
2015年感恩父亲节活动策划方案
2015/05/05 职场文书
未婚证明格式
2015/06/15 职场文书
《我的伯父鲁迅先生》教学反思
2016/02/16 职场文书
会计专业自荐信范文
2019/05/22 职场文书
68句权威创业名言
2019/08/26 职场文书