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 来操作字符串(一些字符串函数)
Feb 15 Javascript
js 全兼容可高亮二级缓冲折叠菜单
Jun 04 Javascript
深入理解JavaScript系列(3) 全面解析Module模式
Jan 15 Javascript
javascript:history.go()和History.back()的区别及应用
Nov 25 Javascript
浅析js中的浮点型运算问题
Jan 06 Javascript
原生javascript实现DIV拖拽并计算重复面积
Jan 02 Javascript
JavaScript实现函数返回多个值的方法
Jun 09 Javascript
jquery+CSS3模拟Path2.0动画菜单效果代码
Aug 31 Javascript
AngularJS ng-repeat数组有重复值的解决方法
Oct 23 Javascript
Express系列之multer上传的使用
Oct 27 Javascript
Vue响应式原理深入解析及注意事项
Dec 11 Javascript
详解vue数组遍历方法forEach和map的原理解析和实际应用
Nov 15 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和AJAX创建RSS聚合器的代码
2007/03/13 PHP
PHP URL路由类实例
2013/11/12 PHP
PHP实现统计在线人数功能示例
2016/10/15 PHP
PHP中静态变量的使用方法实例分析
2016/12/01 PHP
PHP实现APP微信支付的实例讲解
2018/02/10 PHP
php弹出提示框的是实例写法
2019/09/26 PHP
YII2框架中actions的作用与使用方法示例
2020/03/13 PHP
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
2020/08/03 PHP
javascript 打印内容方法小结
2009/11/04 Javascript
FusionCharts图表显示双Y轴双(多)曲线
2012/11/22 Javascript
一个支付页面DEMO附截图
2014/07/22 Javascript
javascript中Math.random()使用详解
2015/04/15 Javascript
使用AngularJS创建自定义的过滤器的方法
2015/06/18 Javascript
AngularJS入门教程之Cookies读写操作示例
2016/11/02 Javascript
详解Javascript几种跨域方式总结
2017/02/27 Javascript
vue获取form表单的值示例
2019/10/29 Javascript
js+canvas实现五子棋小游戏
2020/08/02 Javascript
使用python检测主机存活端口及检查存活主机
2015/10/12 Python
Python实现的计数排序算法示例
2017/11/29 Python
Python简单实现socket信息发送与监听功能示例
2018/01/03 Python
Python中str.join()简单用法示例
2018/03/20 Python
Pandas 同元素多列去重的实例
2018/07/03 Python
详解重置Django migration的常见方式
2019/02/15 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
画pytorch模型图,以及参数计算的方法
2019/08/17 Python
Django mysqlclient安装和使用详解
2020/09/17 Python
CSS3 please 跨浏览器的CSS3产生器
2010/03/14 HTML / CSS
HTML5实现一个能够移动的小坦克示例代码
2013/09/02 HTML / CSS
小学国庆节活动方案
2014/02/11 职场文书
学校工会工作总结2015
2015/05/19 职场文书
四则混合运算教学反思
2016/02/23 职场文书
nginx实现发布静态资源的方法
2021/03/31 Servers
基于python制作简易版学生信息管理系统
2021/04/20 Python
解析CSS 提取图片主题色功能(小技巧)
2021/05/12 HTML / CSS
centos8安装nginx1.9.1的详细过程
2021/08/02 Servers
MongoDB连接数据库并创建数据等使用方法
2021/11/27 MongoDB