24

我正在尝试在移动标记后更新标记的 lat/lng 值。提供的示例使用弹出窗口来显示 lat/lng。

我有一个标记的“dragend”事件侦听器,但是当我提醒 e.latlng 的值时,它返回未定义。

javascript:

function markerDrag(e){
    alert("You dragged to: " + e.latlng);
}

function initialize() {
    // Initialize the map
    var map = L.map('map').setView([38.487, -75.641], 8);
    L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
        attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
        maxZoom: 18
    }).addTo(map);

    // Event Handlers
    map.on('click', function(e){
        var marker = new L.Marker(e.latlng, {draggable:true});
        marker.bindPopup("<strong>"+e.latlng+"</strong>").addTo(map);

        marker.on('dragend', markerDrag);
    });
}


$(document).ready(initialize());

http://jsfiddle.net/rhewitt/Msrpq/4/

4

4 回答 4

21

用于e.target.getLatLng()获取更新位置的纬度。

    // Script for adding marker on map click
    function onMapClick(e) {

        var marker = L.marker(e.latlng, {
                 draggable:true,
                 title:"Resource location",
                 alt:"Resource Location",
                 riseOnHover:true
                }).addTo(map)
                  .bindPopup(e.latlng.toString()).openPopup();

        // #12 : Update marker popup content on changing it's position
        marker.on("dragend",function(e){

            var chagedPos = e.target.getLatLng();
            this.bindPopup(chagedPos.toString()).openPopup();

        });
    }

JSFiddle 演示

于 2014-03-23T19:42:24.997 回答
15

latlng 值不在 e.latlng 中,而是在 e.target._latlng 中。使用控制台。

于 2013-08-22T14:41:31.330 回答
10

在使用e.target._latlng作品时(如this other answer所建议),最好使用

e.target.getLatLng();

这样我们就不会像Leaflet推荐的那样暴露任何私有变量:

私有属性和方法以下划线 (_) 开头。这不会将它们设为私有,只是建议开发人员不要直接使用它们。

于 2016-11-16T20:38:46.897 回答
8

我认为 API 发生了变化。

现在是:const { lat, lng } = e.target.getCenter();

于 2017-04-22T08:47:14.867 回答