我正在尝试在移动标记后更新标记的lat / lng值。提供的示例使用弹出窗口显示lat / lng。
我有一个标记的“dragend”事件监听器,但当我提醒e.latlng的值时,它返回undefined。
的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 © <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());
答案 0 :(得分:16)
latlng值不在e.latlng中,而是在e.target._latlng中。 使用控制台。
答案 1 :(得分:12)
使用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();
});
}
答案 2 :(得分:8)
使用e.target._latlng
时(由this other answer提议),使用
e.target.getLatLng();
这样我们就不会像Leaflet所建议的那样暴露任何私有变量:
私有属性和方法以下划线(_)开头。这不会使它们变得私密,只是建议开发人员不要直接使用它们。
答案 3 :(得分:2)
我认为API发生了变化。
现在是:const { lat, lng } = e.target.getCenter();