js学习总结之DOM2兼容处理重复问题的解决方法


Posted in Javascript onJuly 27, 2017

DOM2兼容处理重复问题的解决方法,具体如下

在解决this问题之后,只需要在每次往自定义属性和事件池当中添加事件的时候进行一下判断就好了,具体代码如下

/*
  bind:处理DOM2级事件绑定的兼容性问题(绑定方法)
  @parameter:
    curEle->要绑定事件的元素
    evenType->要绑定的事件类型("click","mouseover")
    evenFn->要绑定的方法
*/
function bind(curEle,evenType,evenFn){
  if('addEventListener' in document){
    curEle.addEventListener(evenType,evenFn,false);
    return;
  }
  //给evenFn化妆 并且把化妆前的照片贴在自己对应的脑门上
  var tempFn = function(){
    evenFn.call(curEle)
  }
  tempFn.photo = evenFn;
  //首先判断自定义属性之前是否存在,不存在的话创建一个,由于要存储多个化妆后的结果,所以我们让其值是一个数组
  if(!curEle["mybind"+evenType]){//根据不同的事件类型是不同的数组
    curEle["mybind"+evenType] = [];
  }
  //解决重复问题:每一次自己在往自定义属性对应的容器中添加前,看一下是否已经存在,存在的话就不用重新的添加了,同理也不需要往事件池里面存储了
  var ary = curEle["mybind"+evenType];
  for(var i = 0;i<ary.length;i++){
    var cur = ary[i];
    if(cur.photo === evenFn){
      return;
    }
  }
  ary.push(tempFn);
  curEle.attachEvent("on"+evenType,tempFn);
  //这里的开始想法是改变this的指向,把this不指向window
  /*
    box.attachEvent("onclick",function(){
      fn1.call(box)
    })
    这样虽然解决了this的问题,但是又抛出了一个新的问题,不知道该如何删除了(我们不知道匿名函数是谁)
    var tempFn = function(){
      fn1.call(box)
    }
    box.attachEvent("onclick",tempFn);
    box.detachEvent("onclick",tempFn);
  */
}

function unbind(curEle,evenType,evenFn){
  if('removeEventListener' in document){
    curEle.removeEventListener(evenType,evenFn,false);
    return;
  }
  //拿evenFn到curEle["myBind"]这里找化妆后的结果,找到之后再事件池中把化妆后的结果移除事件池
  var ary = curEle['myBind'+evenType];
  for(var i = 0;i<ary.length;i++){
    if(ary[i].photo===evenFn){
      ary.splice(i,1)//找到后 把自己存储的容器中对应的移除掉
      curEle.detachEvent("on"+evenType,ary[i]);//在把事件池中对应的也移除掉
      break;
    }
  }
  
}

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

Javascript 相关文章推荐
Javascript 函数中的参数使用分析
Mar 27 Javascript
js hover 定时器(实例代码)
Nov 12 Javascript
js使用栈来实现10进制转8进制与取除数及余数
Jun 11 Javascript
jquery+CSS3模拟Path2.0动画菜单效果代码
Aug 31 Javascript
基于jQuery插件实现点击小图显示大图效果
May 11 Javascript
js实现短信发送倒计时功能(正则验证)
Feb 10 Javascript
js省市区级联查询(插件版&amp;无插件版)
Mar 21 Javascript
详解http访问解析流程原理
Oct 18 Javascript
Vue 项目中遇到的跨域问题及解决方法(后台php)
Mar 28 Javascript
详解Vue基于vue-quill-editor富文本编辑器使用心得
Jan 03 Javascript
Vue中多个元素、组件的过渡及列表过渡的方法示例
Feb 13 Javascript
bootstrap table插件动态加载表头
Jul 19 Javascript
angular中实现li或者某个元素点击变色的两种方法
Jul 27 #Javascript
js学习总结之DOM2兼容处理顺序问题的解决方法
Jul 27 #Javascript
AngularJS点击添加样式、点击变色设置的实例代码
Jul 27 #Javascript
vue中计算属性(computed)、methods和watched之间的区别
Jul 27 #Javascript
angular2+node.js express打包部署的实战
Jul 27 #Javascript
利用Ionic2 + angular4实现一个地区选择组件
Jul 27 #Javascript
vue单页应用中如何使用jquery的方法示例
Jul 27 #jQuery
You might like
PHP 5.0 Pear安装方法
2006/12/06 PHP
PHP中开发XML应用程序之基础篇 添加节点 删除节点 查询节点 查询节
2010/07/09 PHP
php数组函数序列之krsort()- 对数组的元素键名进行降序排序,保持索引关系
2011/11/02 PHP
php建立Ftp连接的方法
2015/03/07 PHP
Symfony实现行为和模板中取得request参数的方法
2016/03/17 PHP
Yii数据库缓存实例分析
2016/03/29 PHP
PDO::setAttribute讲解
2019/01/29 PHP
js中有关IE版本检测
2012/01/04 Javascript
中文字符串截取的js函数代码
2013/04/17 Javascript
JavaScript通过代码调用Flash显示的方法
2016/02/02 Javascript
第一次接触神奇的Bootstrap
2016/10/14 Javascript
Angular.js与node.js项目里用cookie校验账户登录详解
2017/02/22 Javascript
Webpack 服务器端代码打包的示例代码
2017/09/19 Javascript
jsonp跨域及实现百度首页联想功能的方法
2018/08/30 Javascript
用npm安装vue和vue-cli,并使用webpack创建项目的方法
2018/09/28 Javascript
Vue2.0使用嵌套路由实现页面内容切换/公用一级菜单控制页面内容切换(推荐)
2019/05/08 Javascript
vue-cli3+typescript新建一个项目的思路分析
2019/08/06 Javascript
VUE使用 wx-open-launch-app 组件开发微信打开APP功能
2020/08/11 Javascript
[02:43]2018DOTA2亚洲邀请赛主赛事首日TOP5
2018/04/04 DOTA
[01:00:30]完美世界DOTA2联赛循环赛 Inki vs Matador BO2第二场 10.31
2020/11/02 DOTA
跟老齐学Python之??碌某?? target=
2014/09/12 Python
python动态网页批量爬取
2016/02/14 Python
浅谈利用numpy对矩阵进行归一化处理的方法
2018/07/11 Python
python异步编程 使用yield from过程解析
2019/09/25 Python
Python 网络编程之UDP发送接收数据功能示例【基于socket套接字】
2019/10/11 Python
Python List列表对象内置方法实例详解
2019/10/22 Python
使用PyTorch训练一个图像分类器实例
2020/01/08 Python
Python tcp传输代码实例解析
2020/03/18 Python
经验丰富程序员才知道的8种高级Python技巧
2020/07/27 Python
外贸主管求职简历的自我评价
2013/10/23 职场文书
应届生新闻编辑求职信
2013/11/19 职场文书
协议书范本
2014/04/23 职场文书
抗震救灾标语
2014/06/26 职场文书
个人总结怎么写
2015/02/26 职场文书
7个关于Python的经典基础案例
2021/11/07 Python
使用python求解迷宫问题的三种实现方法
2022/03/17 Python