移动端长按事件

Posted lcazzz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了移动端长按事件相关的知识,希望对你有一定的参考价值。

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

$.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;
  }
})



以上是关于移动端长按事件的主要内容,如果未能解决你的问题,请参考以下文章

移动端长按事件操作

移动端长按效果实现

VUE: 移动端长按弹出确认删除地址

js中模拟移动端长按效果

JS案例 - 基于vue的移动端长按手势

h5移动端阻止浏览器长按事件