javascript - 当用户完成输入而不是按键时运行javascript函数?

标签 javascript jquery keyboard

我想在用户输入完文本框后触发 ajax 请求。我不希望它在每次用户输入字母时都运行该函数,因为这会导致大量的 ajax 请求,但我也不希望他们必须点击 enter 按钮。

有没有办法让我可以检测到用户何时完成输入然后执行 ajax 请求?

在这里使用 jQuery!

最佳答案

所以,我猜想完成打字意味着你只需停下来一会儿,比如 5 秒。因此,考虑到这一点,让我们在用户释放一个键时启动一个计时器,并在他们按下一个键时清除它。我决定有问题的输入是#myInput。

做一些假设......

//setup before functions
var typingTimer;                //timer identifier
var doneTypingInterval = 5000;  //time in ms, 5 seconds for example
var $input = $('#myInput');

//on keyup, start the countdown
$input.on('keyup', function () {
  clearTimeout(typingTimer);
  typingTimer = setTimeout(doneTyping, doneTypingInterval);
});

//on keydown, clear the countdown 
$input.on('keydown', function () {
  clearTimeout(typingTimer);
});

//user is "finished typing," do something
function doneTyping () {
  //do something
}

关于javascript - 当用户完成输入而不是按键时运行javascript函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4220126/

相关文章:

javascript - 全屏时捕捉键盘输入似乎不起作用

javascript - 从 reducer 访问 Redux 存储值,无需控制操作创建者

javascript - CSS - 触摸屏放大时更改背景网址

javascript - .is() 在 Cheerio 中不存在?

javascript - 将 100% 的 div 宽度减少一定数量的像素

javascript - 将 jQuery 插件变成指令

javascript - 从父元素中删除一个元素并将其附加到其他元素

javascript - 将 HighMaps JQuery 的数据更改为本地文件

linux - 我如何统计我的按键频率和计数

ios - 如何显示 UIView 的键盘