如何延迟jQuery中的按键之间的操作。
例如;
例如;
我有这样的东西
if($(this).val().length > 1){ $.post("stuff.PHP",{nStr: "" + $(this).val() + ""},function(data){ if(data.length > 0) { $('#suggestions').show(); $('#autoSuggestionsList').html(data); }else{ $('#suggestions').hide(); } }); }
我想防止发布数据,如果用户不断打字。那么如何能给出0.5秒的延迟?
解决方法
你可以使用jQuery的数据能力来做到这一点,像这样:
$('#mySearch').keyup(function() { clearTimeout($.data(this,'timer')); var wait = setTimeout(search,500); $(this).data('timer',wait); }); function search() { $.post("stuff.PHP",{nStr: "" + $('#mySearch').val() + ""},function(data){ if(data.length > 0) { $('#suggestions').show(); $('#autoSuggestionsList').html(data); }else{ $('#suggestions').hide(); } }); }
这里的主要优点是没有全局变量,如果你想的话,你可以将它包装在setTimeout中的一个匿名函数,只是试图使示例尽可能干净。
原文地址:https://www.jb51.cc/jquery/184436.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。