ajax只按最后一次请求,只执行最后一个Ajax请求

博主遇到一个问题,在输入框中输入超过3个字符时,会触发AJAX请求到PHP文件进行验证。但当输入包含错误字符时,希望只执行最后一个请求并取消其他挂起的请求。尝试使用xhr.abort()来终止请求,但未成功。代码示例中展示了输入框的keyup事件监听和AJAX请求的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我想验证使用jQuery ajax和php的字段。只执行最后一个Ajax请求

当我开始录入多于3个字符时,它将请求发送到php文件,但是我的问题是当我点击3个有效字符并且第4个无效时,我必须等待执行请求4次。

我想只执行最后一个请求,并杀死其他挂起的请求

我想:

xhr = $.ajax(//...);

xhr.abort();

if(typeof xhr !== 'undefined')

xhr.abort();

xhr = $.ajax(//...);

,但它不工作

这是我的代码:

// Check validation errors

var minLength = 3;

$('input[name^="data"][type=text]').on('keyup', function(){

var input = $(this);

var value = $.trim(input.val());

var url = input.data('url');

var div = input.parent();

var serialized = input.serialize();

if(value.length >= minLength){

$.ajax({

type: 'POST',

url: url+'.json',

data: serialized,

dataType: 'json',

success: function(data){

var error = data.error;

if(error){

div.removeClass('valid').addClass('invalid');

}else{

div.removeClass('invalid').addClass('valid');

}

}

});

}

});

+1

看看[this throttle/debounce](http://benalman.com/projects/jquery-throttle-debounce-plugin/)插件来自Ben Alman –

2013-02-12 20:50:06

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值