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 火狐(firefox)不显示本地图片问题解决
Jul 05 Javascript
JS仿flash上传头像效果实现代码
Jul 18 Javascript
关于innerHTML后丢失动态绑定的EVENT问题解决方法
May 19 Javascript
js中substr,substring,indexOf,lastIndexOf的用法小结
Dec 27 Javascript
jquery实现的鼠标拖动排序Li或Table
May 04 Javascript
jquery+css实现动感的图片切换效果
Nov 25 Javascript
js实现textarea限制输入字数
Feb 13 Javascript
从零学习node.js之express入门(六)
Feb 25 Javascript
EasyUI的TreeGrid的过滤功能的解决思路
Aug 08 Javascript
在 Vue-CLI 中引入 simple-mock实现简易的 API Mock 接口数据模拟
Nov 28 Javascript
vue+element tabs选项卡分页效果
Jun 29 Javascript
JavaScript实现世界各地时间显示
Sep 07 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
如何使用Strace调试工具
2013/06/03 PHP
ThinkPHP之N方法实例详解
2014/06/20 PHP
php防止用户重复提交表单
2015/11/02 PHP
3种方法轻松处理php开发中emoji表情的问题
2016/07/18 PHP
PHP递归删除多维数组中的某个值
2017/04/17 PHP
Laravel中七个非常有用但很少人知道的Carbon方法
2017/09/21 PHP
Javascript 面向对象之重载
2010/05/04 Javascript
也说JavaScript中String类的replace函数
2011/09/22 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
JQuery Highcharts 动态生成图表的方法
2013/11/15 Javascript
js验证IP及子网掩码的合法性有效性示例
2014/04/30 Javascript
window.returnValue使用方法示例介绍
2014/07/03 Javascript
js获取元素外链样式的方法
2015/01/27 Javascript
js如何判断输入字符串长度
2015/12/16 Javascript
浅谈Node.js:Buffer模块
2016/12/05 Javascript
微信小程序自定义prompt组件步骤详解
2018/06/12 Javascript
如何在 JavaScript 中更好地利用数组
2018/09/27 Javascript
使用pkg打包Node.js应用的方法步骤
2018/10/19 Javascript
JS中超越现实的匿名函数用法实例分析
2019/06/21 Javascript
React实现类似淘宝tab居中切换效果的示例代码
2020/06/02 Javascript
[01:21:36]CHAOS vs Alliacne 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
python 解析html之BeautifulSoup
2009/07/07 Python
Python编程使用NLTK进行自然语言处理详解
2017/11/16 Python
python实现音乐下载器
2018/04/15 Python
python 移动图片到另外一个文件夹的实例
2019/01/10 Python
python 自动轨迹绘制的实例代码
2019/07/05 Python
jupyter notebook插入本地图片的实现
2020/04/13 Python
DataFrame 数据合并实现(merge,join,concat)
2020/06/14 Python
科沃斯机器人官网商城:Ecovacs
2016/08/29 全球购物
StubHub澳大利亚:购买或出售您的门票
2019/08/01 全球购物
文秘求职信范文
2014/04/10 职场文书
客房部经理岗位职责
2015/02/02 职场文书
公司财务部岗位职责
2015/04/14 职场文书
2015年化工厂工作总结
2015/05/04 职场文书
python设置 matplotlib 正确显示中文的四种方式
2021/05/10 Python
Java中生成微信小程序太阳码的实现方案
2022/06/01 Java/Android