关闭包含大量标记的Yahoo地图时,请避免挂起

Dav*_*ick 5 javascript maps yui yahoo-maps

我有一张带有大量标记的雅虎地图(~500).地图执行得很好,直到我关闭页面,此时它暂停(在Firefox中)并显示"停止运行此脚本?" 对话框(在IE7中).如果给予足够长的时间,脚本就会完成其工作.

我能做些什么来减少这种延迟吗?

这个剥离的代码表明了这个问题:

<script type="text/javascript">
var map = new YMap(document.getElementById('map'));
map.drawZoomAndCenter("Algeria", 17);

for (var i = 0; i < 500; i += 1) {
    var geoPoint = new YGeoPoint((Math.random()-0.5)*180.0, (Math.random()-0.5)*360.0);
    var marker = new YMarker(geoPoint);
    map.addOverlay(marker);
}
</script> 
Run Code Online (Sandbox Code Playgroud)

如果您动态添加和删除标记,我知道事件处理程序会发生一些内存泄漏,但这些是静态的(尽管问题可能是相关的).哦,我知道地图上的这些标记可能不是传达数据的最佳方式,但这不是我正在寻找的答案;)

编辑:根据以下建议,我尝试过:

window.onbeforeunload = function() {
    map.removeMarkersAll();
}
Run Code Online (Sandbox Code Playgroud)

window.onbeforeunload = function() {
    mapElement = document.getElementById('map');
    mapElement.parentNode.removeChild(mapElement);
}
Run Code Online (Sandbox Code Playgroud)

但都没有奏效:(

Dio*_*ane 0

您可以尝试删除所有标记,甚至使用“onbeforeunload”事件从 DOM 中删除地图。