我正在尝试使用 jQuery AJAX 调用预加载一些图像,但是在将(url)字符串传递到 AJAX 调用的成功函数中的函数中时遇到了真正的问题(如果有意义的话)。
这是我的代码:
//preloader for images on gallery pages
window.onload = function() {
setTimeout(function() {
var urls = ["./img/party/"]; //just one to get started
for ( var i = 0; i < urls.length; i++ ) {
$.ajax({
url: urls[i],
success: function(data,url) {
$(data).find("a:contains(.jpg)").each(function(url) {
new Image().src = url + $(this).attr("href");
});
}
});
};
}, 1000);
};
可以看到我(失败的)尝试将 url 传递到.each()
调用中 -url
最终采用递增整数的值。不知道为什么或这些与什么有关,也许是 jpg 文件的数量?
...无论如何,它当然应该采用我原始 urls 数组中的单个值。
感谢您的帮助 - 我似乎总是对这些回调感到有些困惑。
进展?
所以,我有点胡思乱想,留意@ron tornambe 和@PiSquared 的评论,目前我在这里:
//preloader for images on gallery pages
window.onload = function() {
var urls = ["./img/party/","./img/wedding/","./img/wedding/tree/"];
setTimeout(function() {
for ( var i = 0; i < urls.length; i++ ) {
$.ajax({
url: urls[i],
success: function(data) {
image_link(data,i);
function image_link(data, i) {
$(data).find("a:contains(.jpg)").each(function(){
console.log(i);
new Image().src = urls[i] + $(this).attr("href");
});
}
}
});
};
}, 1000);
};
我试着把image_link(data, i)
这里和任何地方(在每个嵌套函数等),但我得到相同的结果:值i
只记录为 3。我怀疑这是因为所有引用都i
指向同一事物并且由异步任务实际进入image_link(data, i)
循环for...
的时间结束并完成(因此值为 3)。不用说,这给出urls[i]
了“未定义”。
任何(更多)提示如何解决这个问题?