【发布时间】:2023-04-04 11:47:01
【问题描述】:
对不起,如果这是微不足道的,但我是 JS 的新手,并且已经解决了这个问题几个小时无济于事。
function initialize() {
geocoder = new google.maps.Geocoder();
var latlng = new google.maps.LatLng(-34.397, 150.644);
var myOptions = {
zoom: 12,
center: latlng,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
}
var markersArray = [];
var infowindowArray = [];
function addMarker(location) {
marker = new google.maps.Marker({
position: location,
map: map
});
markersArray.push(marker);
}
function addInfowindow(string) {
infowindow = new google.maps.InfoWindow({content: string});
infowindowArray.push(infowindow);
}
function findvenues(latitudelongitude) {
$.get("venuefinder.php", { latlong:latitudelongitude.Ka+","+latitudelongitude.La }, function(data){
var myObject = eval('(' + data + ')');
for(x in myObject.response.venues){
var latlonglocation = new google.maps.LatLng(myObject.response.venues[x].location.lat,myObject.response.venues[x].location.lng);
addMarker(latlonglocation);
addInfowindow(myObject.response.venues[x].name);
google.maps.event.addListener(markersArray[x], 'click', function() {infowindowArray[x].open(map,markersArray[x]);});
console.log(markersArray[x],infowindowArray[x]);
}
});
调用 findvenues 时,应该添加 infowindow 点击事件。当我单击图标时,总是会打开与 infowindows 数组中最后一个元素相同的 infowindow。
但是,如果我手动输入以下代码,它可以工作:
google.maps.event.addListener(markersArray[0], 'click', function() {infowindowArray[0].open(map,markersArray[0]);});
google.maps.event.addListener(markersArray[1], 'click', function() {infowindowArray[1].open(map,markersArray[1]);});
我需要它是动态的...我做错了什么?如果问题不清楚,请告诉我,我会尽力澄清。
【问题讨论】:
标签: javascript jquery google-maps-api-3