首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将时间间隔内触发的鼠标滚轮滚动事件减少为单个事件

如何将时间间隔内触发的鼠标滚轮滚动事件减少为单个事件
EN

Stack Overflow用户
提问于 2015-07-31 05:38:02
回答 2查看 1.4K关注 0票数 3

目前在我的网站,我有一个鼠标轮功能,滚动用户设置位置的网页。但是,当用户滚动得有点快,并且不限制滚动到单个鼠标轮滚动单元时,此函数会触发多次。我如何在特定的时间间隔(比如一秒)内将所有的鼠标轮滚动事件都取下来,并使其触发我的函数一次?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-07-31 06:18:35

您可以在事件处理程序上使用脱脂下划线 / 房客提供了取消功能,但jQuery没有。从这里获取的一个简单示例如下所示:

代码语言:javascript
复制
function debounce(func, wait, immediate) {
    var timeout;
    return function() {
        var context = this, args = arguments;
        var later = function() {
            timeout = null;
            if (!immediate) func.apply(context, args);
        };
        var callNow = immediate && !timeout;
        clearTimeout(timeout);
        timeout = setTimeout(later, wait);
        if (callNow) func.apply(context, args);
    };
};

一旦你有了它,你就可以像这样使用它:

代码语言:javascript
复制
var delay = 1000; // 1s

var handlerFunction = debounce(function (e) {
  console.log(1);
}, delay);

$(document).on('scroll', handlerFunction);

在上次调用处理程序之后,您的处理程序实际上只会执行1000 is。

JSBIN让你玩。

票数 4
EN

Stack Overflow用户

发布于 2015-07-31 06:13:27

此jQuery代码允许您设置以毫秒为单位的间隔。

代码语言:javascript
复制
var intervalMs = 2000;

var last = 0;
$(document).scroll(function() {
  var now = new Date().getTime();
  if (last + intervalMs < now) {
    last = now;
    
    // do stuff
  }
});

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31738803

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档