码迷,mamicode.com
首页 > 其他好文 > 详细

双击事件失效解决办法

时间:2017-05-19 12:52:38      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:null   this   new   冲突   ons   gettime   事件   click   date   

某些时候,双击事件会失效,模拟办法解决双击失效后,而同时我又不想在该元素上触发两次单击事件,解决办法如下:

var dbclickTime={
prev:0, next:0//模拟触发双击
};
var clickConflict={//解决单击事件和双击事件的冲突
_timeout:null,
set:function (fn) {
this.clear();
this._timeout=window.setTimeout(fn,400);
},
clear:function () {
if(this._timeout){
window.clearTimeout(this._timeout);
this._timeout=0;
}
}
};

//code 事件托管
document.addEventListener("click",function (e) {
if(dbclickTime.prev==0){
dbclickTime.prev=dbclickTime.next=new Date().getTime();
}else{
dbclickTime.prev=dbclickTime.next;
dbclickTime.next=new Date().getTime()
}

if(true){//托管的元素
clickConflict.set(function () {
          console.log("click");
          //do something
        });
}

if(dbclickTime.next-dbclickTime.prev<300){
console.log("dblick");
clickConflict.clear();
if(true){//托管的元素
//do something
}
}
},true);

双击事件失效解决办法

标签:null   this   new   冲突   ons   gettime   事件   click   date   

原文地址:http://www.cnblogs.com/callmeguxi/p/6877699.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!