小编典典

jQuery AJAX调用for循环

ajax

我是AJAX的新手,我正在编写一个用户脚本,该脚本将处理页面上的一堆链接并为每个链接进行AJAX调用。

for (var i = 0; i < linkList.length; i++)
{
    $.ajax({
        url: linkList[i].getAttribute("href"),
        cache: false
    }).done(function( html )
    {
        var hasAppended = false;
        if (html.indexOf('someStringOnGottenPage') != -1 && !hasAppended)
        {
            hasAppended = true;
            var id = linkList[i].getAttribute("href").substring(linkList[i].getAttribute("href").indexOf('='));
            $( "#links a[href*='" + id + "']" ).append(' THIS PAGE CONTAINS SPECIFIED DATA');
        }
    });
}

简单地说,我有一个包含链接列表的页面。我希望遍历链接并获取AJAX来处理每个链接页面的内容,并报告该页面是否包含指定内容。

我遇到的问题是用于遍历linkList的[i]的值始终为6,应该永远不会。我假设我需要传递一些数据,以便当.done最终触发时,它从AJAX首次触发时知道其[i]值,而在.done之后触发时则不知道[i]的值。

在首次调用AJAX时,如何确保.done知道[i]值?


阅读 309

收藏
2020-07-26

共1个答案

小编典典

最简单的方法是使用闭包。每当循环中有异步的东西时,它都是同一件事。

for (var i .....) {
  asynchronousFunction(function() {
    use(i);
  }
}

在此伪代码段中,内部函数捕获引用的_存储位置_i。循环运行,i递增到其最终值,然后开始调用异步回调,所有这些回调都查找完全相同的 位置(而不是值)。

通用解决方案是这样的:

for (var i .....) {
  (function (i) {
    asynchronousFunction(function() {
      use(i);
    });
  })(i);
}

将循环的全部内容包装在一个自执行函数中。

在这里,outer 的_值_i被传递给包装的自执行匿名函数;这个唯一值的位置被异步回调捕获。这样,每个异步都会获得自己的值,该值是在调用自执行函数时确定的。

2020-07-26