我认为这里真正的问题是“在您的页面上,是否初始化地图意味着什么?”
在您提到的评论中,您可能在页面上有大约 200 个地图。当然,您的意思不是说您已经new google.maps.Map()
为这 200 张地图中的每一张都调用过吗?这似乎会导致加载页面非常缓慢。
实际上,您是否有 200 个容器<div>
元素,其中一些可能已经使用new google.maps.Map()
as 在您的initialize()
函数中使用 map 进行了初始化,而其中一些尚未使用该代码进行初始化,但在<div>
您这样做之前只是空元素?
是不是你真正感兴趣的不是某个地图是否已完全加载,而只是你是否已经开始加载它?
例如,您可以有一个页面,您可以在其中单击一个框并开始加载地图。地图开始加载后,您不想在第二次单击时重新加载它。在这种情况下,您感兴趣的不是地图是否已完全加载,而是它是否已经开始加载。
如果这就是您正在做的事情,那么测试它的一种简单方法是查看<div>
元素是否有任何子元素:
function hasMap( id ) {
return !! document.getElementById(id).firstChild;
}
if( hasMap("map-canvas-0") ) {
// That map has loaded or at least has started loading
}
如果您需要确定地图是否已完全加载,那么idle
事件就是执行此操作的方法。在这一点上,究竟是使用隐藏字段还是 JavaScript 对象确实是一个折腾。JavaScript 对象非常简单:
var mapsLoaded = {};
function loadMap( id, lat, lng, zoom ) {
var options = {
center: new google.maps.LatLng( lat, lng ),
zoom: zoom,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var container = document.getElementById( id );
var map = new google.maps.Map( container, options );
google.maps.event.addListener( map, 'idle' function() {
mapsLoaded[id] = true;
});
}
现在,如果您想知道是否加载了特定 ID 的地图,只需使用:
mapsLoaded[id]
例如
mapsLoaded['map-canvas-0']
将告诉您示例中的地图是否已满载。
如果这个答案看起来有点离谱,那么更全面地解释你在做什么呢?你什么时候创建你的容器元素——都是在页面初始化的时候,还是以后?何时以及如何创建地图?在用户点击或什么?容器 ID 是如何生成的?在什么情况下您需要知道地图是否已创建——您何时需要知道这一点以及为什么?
你越能清楚地说明这些问题,就越有可能有人可以帮助你给出具体的答案——你就越有可能有一个“啊哈”的时刻并确切地知道该怎么做。:-)