首页 > 移动平台 > 详细

移动端长按事件

时间:2017-07-05 15:07:07      阅读:586      评论:0      收藏:0      [点我收藏+]

   第一种方法:这个例子我获取不到当前长按元素;

$.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);
    }
}
调用:
$(‘.object‘).longPress(function(){
    //do something...
});


第二种方法:这个方法能获取到当前元素;

var timeOutEvent=0,cardId;
  $(".card-list li").on({
  touchstart: function(e){
    var that = this;
    timeOutEvent = setTimeout(function () {
      //长按触发事件
      timeOutEvent = 0;
      alert(‘我在长按‘);
    },800);
    // e.preventDefault();
  },
  touchmove: function(){
    clearTimeout(timeOutEvent);
    timeOutEvent = 0;
  },
  touchend: function(){
    clearTimeout(timeOutEvent);
    // return false;
  }
})



移动端长按事件

原文:http://www.cnblogs.com/lcazzz/p/7121174.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!