好的,我有一张地图上有一些标记。地图上有一个应该获得最接近标记的点击事件,但是当find_closest_marker(事件)函数运行时,它会在map.markers.length上断言,表示它未定义。
这是我试图 http://jsfiddle.net/VyzFq/7/
的链接任何人都可以请告诉我这里我出错的地方。
答案 0 :(得分:4)
看起来有几个问题:
1)尚未声明map.markers数组。将它声明在for循环之上,并将标记推到标记数组上。
...
var infowindow = new google.maps.InfoWindow();
var marker, i;
map.markers = []; // ADD THIS LINE
for (i = 0; i < locations.length; i++) {
marker = new google.maps.Marker({
position: new google.maps.LatLng(locations[i][1], locations[i][2]),
map: map
});
map.markers.push(marker); // ADD THIS LINE
...
2)find_closest_point函数无法看到map变量。将find_closest_point函数移动到要添加click事件侦听器的范围:
// CHANGE THIS LINE
google.maps.event.addListener(map, 'click', find_closest_marker);
// TO:
google.maps.event.addListener(map, 'click', function( event ) {
var lat = event.latLng.lat();
var lng = event.latLng.lng();
var R = 6371;
var distances = [];
var closest = -1;
for( i=0;i<map.markers.length; i++ ) {
var mlat = map.markers[i].position.lat();
var mlng = map.markers[i].position.lng();
var dLat = rad(mlat - lat);
var dLong = rad(mlng - lng);
var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(rad(lat)) * Math.cos(rad(lat)) * Math.sin(dLong/2) * Math.sin(dLong/2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
var d = R * c;
distances[i] = d;
if ( closest == -1 || d < distances[closest] ) {
closest = i;
}
}
alert(map.markers[closest].title);
});