微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Jquery在最后一个按键后2秒运行代码

我正在为一个网站自动搜索功能.

它使用ajax来查询api.

在输入3个字符之后,它将在每个按键上搜索.

我想要的是

Case1:
User enters tes
2 seconds pass
search performed

Case2:
User enters tes
1 second pass
user presses t
2 seconds pass
search is performed on test Case3:
User enters tes
1 second passes
user presses t
1.5 seconds pass
user presses i
1.5 seconds pass
user presses n
1.5 seconds pass
user presses g
2 seconds pass
search in performed on testing

所以你可以看到,
只有在按下按键后的两秒钟内没有按下按键(或糊状物)时才执行搜索动作.

我的基本想法是.

在keydown
调用设置超时的功能,
函数还设置一个包含文本框中最后一个条目的变量.
当超时到期时,它将检查框中的值,以查看它是否与变量中的值相匹配.

如果他们匹配,那么没有变化.
所以做搜索

如果他们不做任何事情,因为从后续的按键的超时将跟随做同样的检查.

这是唯一/最好的方法吗?

解决方法

以下功能Remy Sharp将做的诀窍:
function throttle(f,delay){
    var timer = null;
    return function(){
        var context = this,args = arguments;
        clearTimeout(timer);
        timer = window.setTimeout(function(){
            f.apply(context,args);
        },delay || 500);
    };
}

在上面的代码中,f是要调节的函数,delay是上次调用后等待的毫秒数(如果省略,认为500).节流器返回一个包装函数,它清除以前调用中的任何现有超时,然后设置一个超时时间延迟毫秒以调用f.引用返回函数的参数用于调用f,确保f接收它期望的参数.

你应该使用它如下:

$('#search').keyup(throttle(function(){
    // do the search if criteria is met
}));

原文地址:https://www.jb51.cc/jquery/179604.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐