我正在尝试让我的叠加层显示得更慢,而不是同时显示所有叠加层。代码完美无缺,直到我添加setTimeout。当我尝试运行它时,控制台说没有定义latLng。
搜索后,我发现很多人都有类似的问题,但似乎没有人回答我的问题。
这是功能。如果您需要更多代码,请告诉我。
function getAndDrop() {
$.ajax({
url : 'php/locationarray.php',
success : function(data) {
latLng = data.split(" ");
for ( i = 0; i < latLng.length; i++) {
setTimeout(function(){
var loc = latLng[i].split("|");
if (marker.length > maxOverlays)
clearSingleOverlay();
addMarker(loc[0], loc[1]);
}, i*200);
}
}
});
}
编辑:latLng被定义为全局上面的。这是当地的。我试图调试
使其全局化答案 0 :(得分:5)
你需要一个闭包:
success : function(data) {
var latLng = data.split(" ");
for ( i = 0; i < latLng.length; i++) {
(function(LL){
setTimeout(function(){
var loc = LL.split("|");
if (marker.length > maxOverlays)
clearSingleOverlay();
addMarker(loc[0], loc[1]);
}, i*200);
})(latLng[i]);
}
}
请在此处阅读澄清说明:Please explain the use of JavaScript closures in loops
PS。你应该创建一个专用的函数来处理循环中的处理:
ie:for(...)handleCurrent();
答案 1 :(得分:-1)
这是因为latLng
在闭包中不可用。您可以尝试在var
声明之前添加latLng
:
success : function(data) {
var latLng = data.split(" ");
for ( i = 0; i < latLng.length; i++) {
setTimeout(function(){
var loc = latLng[i].split("|");
if (marker.length > maxOverlays)
clearSingleOverlay();
addMarker(loc[0], loc[1]);
}, i*200);
}
}