更改所有标记的拖动状态

时间:2017-01-25 22:55:58

标签: leaflet leaflet.markercluster

我使用的是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()

上得到了Exception
Uncaught TypeError: Cannot read property 'classList' of null

有人知道这样做的正确方法吗?

提前致谢!

1 个答案:

答案 0 :(得分:1)

forEach方法中MarkerClusterGroup方法的逻辑似乎在拖动蜘蛛状标记后迭代地图上不可见的标记。然后启用拖动的逻辑失败,因为标记没有图标实例,因为它已从地图中删除。

我已经清理了可重现的示例,并在https://playground-leaflet.rhcloud.com/qate/1/edit?html,output处留下了副本 - 我强烈建议您将其转换为good bug report中的Leaflet.MarkerCluster

您还可以检查每个标记是否具有marker._map私有属性,以检查它们是否在地图上,并跳过那些不是,但这可能导致其他问题。