欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

如何实现ajax延时发送在空闲之后去发送ajax请求

程序员文章站 2023-08-26 10:20:40
很多时候,我们都会遇到例如关键字搜索的功能 我们第一的想法,肯定是绑定响应的keyup事件,然后将得到的keyword,请求一个ajax返回响应的数据处理 但是,这个时候,...

很多时候,我们都会遇到例如关键字搜索的功能

我们第一的想法,肯定是绑定响应的keyup事件,然后将得到的keyword,请求一个ajax返回响应的数据处理

但是,这个时候,如果简单绑定keyup事件。那么,每一次的敲击键盘操作都会发送一个ajax请求,这显然不是我们希望的。

我们希望,尽量在空闲之后去发送ajax请求:

因此,我们设定用户在不敲击键盘之后1s,才去发送这个ajax请求

复制代码 代码如下:

var timeout;
onkeyup = function() {
cleartimeout(timeout);
timeout = settimeout(function() {
ajax请求
}, 1000);
}

当然,可以使用另外一种思路:

阻断掉发出的ajax请求:
复制代码 代码如下:

if (request) {
request.abort();
}
request = $.ajax( )

但是这个ajax请求,最好阻断在ajax发出之前