我使用的是Leaflet.markercluster 1.0.1
我尝试在地图上添加按钮,以便用户可以进入编辑模式'。单击该按钮,它应切换所有标记的拖动状态。我真的不知道如何正确实现,但我写了那段代码
var drag = false;
$('#button').on('click', function () {
drag = !drag;
markers.eachLayer(function (marker) {
marker.options.draggable = drag;
if (marker.dragging) {
drag ? marker.dragging.enable() : marker.dragging.disable();
}
});
});
它工作了一段时间,但后来我在.enable()
上得到了ExceptionUncaught TypeError: Cannot read property 'classList' of null
有人知道这样做的正确方法吗?
提前致谢!
答案 0 :(得分:1)
forEach
方法中MarkerClusterGroup
方法的逻辑似乎在拖动蜘蛛状标记后迭代地图上不可见的标记。然后启用拖动的逻辑失败,因为标记没有图标实例,因为它已从地图中删除。
我已经清理了可重现的示例,并在https://playground-leaflet.rhcloud.com/qate/1/edit?html,output处留下了副本 - 我强烈建议您将其转换为good bug report中的Leaflet.MarkerCluster。
您还可以检查每个标记是否具有marker._map
私有属性,以检查它们是否在地图上,并跳过那些不是,但这可能导致其他问题。