大佬教程收集整理的这篇文章主要介绍了Jquery在最后一个按键后2秒运行代码,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
它使用ajax来查询api.
在输入3个字符之后,它将在每个按键上搜索.
我想要的是
所以你可以看到,
只有在按下按键后的两秒钟内没有按下按键(或糊状物)时才执行搜索动作.
我的基本想法是.
在keydown
调用设置超时的功能,
该函数还设置一个包含文本框中最后一个条目的变量.
当超时到期时,它将检查框中的值,以查看它是否与变量中的值相匹配.
如果他们匹配,那么没有变化.
所以做搜索
如果他们不做任何事情,因为从后续的按键的超时将跟随做同样的检查.
这是唯一/最好的方法吗?
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 }));
以上是大佬教程为你收集整理的Jquery在最后一个按键后2秒运行代码全部内容,希望文章能够帮你解决Jquery在最后一个按键后2秒运行代码所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。