我在一个循环中进行了多次 jQuery ajax 调用。每次 ajax 调用之一返回时,我都需要引用与原始 ajax 调用对应的值。我当前的代码无法正常工作,因为 lskey
变量的值已被进一步的循环迭代更改。
代码如下:
for (var i = 0, len = localStorage.length; i < len; i++) {
var lskey = localStorage.key(i);
if (lskey.substr(0, 4) === 'form') {
var postdata = localStorage.getItem(lskey); // Get the form data
$.ajax({
type: "POST",
async: "false",
url: "/Profile/PostForm",
data: postdata,
success: function (data) {
$('#rollinginfo').append('<br>' + data + ',key=' + lskey);
localStorage.removeItem(lskey); // Remove the relevant localStorage entry
}
, error: function (data) { $('#rollinginfo').append('<br />ERR:' + data); }
});
}
}
问题是每次循环执行时 lskey
都会被更改,因此成功回调没有对调用时存在的 lskey 值的引用。
如何为每个成功回调引用正确的 lskey
值?
最佳答案
for (var i = 0, len = localStorage.length; i < len; i++) {
var lskey = localStorage.key(i);
if (lskey.substr(0, 4) === 'form') {
var postdata = localStorage.getItem(lskey); // Get the form data
$.ajax({
type: "POST",
async: "false",
url: "/Profile/PostForm",
data: postdata,
local_lskey: lskey
success: function (data) {
$('#rollinginfo').append('<br>' + data + ',key=' + lskey);
localStorage.removeItem(this.local_lskey); // Remove the relevant localStorage entry
}
, error: function (data) { $('#rollinginfo').append('<br />ERR:' + data); }
});
}
}
这应该有效。
关于javascript - jQuery Ajax 循环调用丢失局部变量引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5871107/