我是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]值?
最简单的方法是使用闭包。每当循环中有异步的东西时,它都是同一件事。
for (var i .....) { asynchronousFunction(function() { use(i); } }
在此伪代码段中,内部函数捕获引用的_存储位置_i。循环运行,i递增到其最终值,然后开始调用异步回调,所有这些回调都查找完全相同的 位置(而不是值)。
i
通用解决方案是这样的:
for (var i .....) { (function (i) { asynchronousFunction(function() { use(i); }); })(i); }
将循环的全部内容包装在一个自执行函数中。
在这里,outer 的_值_i被传递给包装的自执行匿名函数;这个唯一值的位置被异步回调捕获。这样,每个异步都会获得自己的值,该值是在调用自执行函数时确定的。