我正在创建一个基于边界框和缩放级别加载和销毁标记的地图。我在正确删除标记时遇到了真正的问题,它似乎有时在某些情况下有效。
我有一个包含标记信息的对象,其中还包含谷歌地图标记对象。我的代码根据边界框或缩放级别检测是否应该删除市场。我将标记对象设置为“setMap(null);” 并且使用萤火虫我可以看到它被设置,然后我完全删除父对象并且对象数据长度被正确更新。
当一个标记被删除时,我输出到萤火虫控制台,似乎正在工作,我可以看到标记没有从 ajax 调用重新创建边界框更改上的标记。
然而,如果我放大地图,我有时会看到标记被移除,如果我缩小,然后按住鼠标平移回来。或者,如果我第一次缩小,有时标记会全部被删除,但如果我再次放大,那么它们不会被删除。
我的代码逻辑一定有问题,我很难过。
可以查看 http://www.trailforks.com/map/test.php?lat=49.352247&lon=-123.202413 的 源码http://www.trailforks.com/map/includes/map.js
删除标记的代码在底部
function clearMarkerMemory(mapItem, i) {
google.maps.event.removeListener(mapItem.lis); // remove stored listener
mapper.data[i].obj.setMap(null); // remove marker
mapper.data.splice(i, 1);
console.log("removed marker "+mapItem.icon+":"+mapItem.nid+' '+mapItem.name);
};
我在控制台中添加了更多调试,转到地图的一个简单区域,只有 2 个标记http://www.trailforks.com/map/test.php?lat=49.43210641783767&lon=-123.49878636730955&z=14
我可以看到创建的标记,然后稍微移动地图并看到标记没有重新创建,因为它们是在标记对象中检测到的。然后我移动视口,使其中一个标记离开屏幕,我可以看到标记已被移除并且标记对象长度更新。但是,如果我将地图平移回标记上,它仍然在地图上。