美文网首页
解决jQuery双击事件会触发单击事件的问题

解决jQuery双击事件会触发单击事件的问题

作者: 东方飞鱼 | 来源:发表于2019-03-20 16:06 被阅读0次

    同一个元素上,绑定多种事件类型,比较常见的是单击事件和一些鼠标事件,一般而言影响不大。但是如果同时绑定单击事件和双击事件呢?

    其实,只要能够想明白的话,解决方案也比较简单,我们想象一下单击事件执行过程:mousedown, mouseup, click。双击事件的执行过程呢?mousedown, mouseup, click; mousedown, mouseup, click。仔细看,其实双击事件就是执行了两次单击事件,那这种情况下,怎么才能避免触发单击事件呢?

    奥秘就在于延迟定时器setTimeout,单击事件延迟执行,如果检测到连续点击的话,就认为是双击事件,不在执行单击事件。

    //  单击事件<br>var timer = null;
    $('.mask-body').on('click', '.leaver-student', function () {   // 点击输入框展开下拉列表
      clearTimeout(timer);
      timer = setTimeout(function () {<br>   // 这里采用执行自定义事件的方式
        $('.leaver-student').trigger('slide');     
      }, 300);   // 延迟300ms执行单击事件
    });<br><br>
    
    //  双击输入框时可以输入学生姓名  双击事件
    $('.mask-body').on('dblclick', '.leaver-student', function (ev) {
      ev.stopPropagation();
      clearTimeout(timer);
      $('.leavers li').trigger('click');
      $(this).removeAttr('readonly').val('').focus();
    });
    

    由此扩展出去,在触摸屏上触发滑动事件时,为什么没有触发单击事件呢?
    事实上采用的是相同的方式,在点击事件时,延迟执行,以便设备确认这次操作究竟是不是真正的点击事件。

    原文链接:jquery双击事件会触发单击事件

    相关文章

      网友评论

          本文标题:解决jQuery双击事件会触发单击事件的问题

          本文链接:https://www.haomeiwen.com/subject/dkctvqtx.html