ajax重复被调用,重复jQuery ajax调用

Wiktor Bedna..

10

更好的方法是使用setTimeout,因此您只在前一个请求完成时发出请求.

应该怎么做

想象一下,由于某种原因(服务器故障,网络错误)的请求需要比定义的时间更长的时间.你会有很多同时发出的请求,这没什么好处的.如果您决定将未来的时间差从10个缩短到1秒,该怎么办?

$(function() {

var storiesInterval = 10 * 1000;

var fetchNews = function() {

console.log('Sending AJAX request...');

$.ajax({

type: "GET",

url: "newstitles.php",

data: {

user: 'success',

some: ['other', 'data']

}

}).done(function(msg) {

$(msg).appendTo("#edix");

console.log('success');

}).fail(function() {

console.log('error');

}).always(function() {

// Schedule the next request after this one completes,

// even after error

console.log('Waiting ' + (storiesInterval / 1000) + ' seconds');

setTimeout(fetchNews, storiesInterval);

});

}

// Fetch news immediately, then every 10 seconds AFTER previous request finishes

fetchNews();

});

我知道,6年后.但是,我认为这对其他人来说是值得的.

为什么OP的代码不起作用?

值得注意的是,您的代码主要不起作用,因为您将ajaxd()函数调用作为字符串传递给setInterval.这不是一个好的做法,部分是因为setInterval期望全局定义功能.您应该使用对函数的引用,就像在我的示例中一样.这样,定义函数的位置和匿名与否都无关紧要.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值