您的位置:首页 > 移动开发 > WebAPP

基于原生JavaScript进行扩展模拟用户长按事件(webapp)

2016-11-03 20:09 483 查看
QQ、微信等约炮聊天软件中,长按好友头像时会有@该好友的功能。今天我要为公司的IM实现这个功能啦,本项目原先是基于mui,其中mui有个longtap事件表示可以监听用户长按事件,但是我试了一下好像效果不太好,还是重新搞个插件吧,下面是基于fn进行扩展,所有jq对象都可以使用。

$.fn.longPress = function(fn) {
var timeout = undefined;
var $this = this;
for(var i = 0;i<$this.length;i++){
$this[i].addEventListener('touchstart', function(event) {
timeout = setTimeout(fn, 800);  //长按时间超过800ms,则执行传入的方法
}, false);
$this[i].addEventListener('touchend', function(event) {
clearTimeout(timeout);  //长按时间少于800ms,不会执行传入的方法
}, false);
}
}


调用方式:$(".xxx").longPress(function(){ //执行具体业务逻辑  })
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息