Вот код javascript, который я использовал при отображении одного маркера за раз.
После обыска почти 3 часов я понял это и простой способ, если добавить несколько маркеров таким образом
var markerArray=[];
for (var i = 0; i < markers.length; i++)
{
var newMarker = new google.maps.Marker({
map: map,
position: new google.maps.LatLng(markers[i].Latitude, markers[i].Longitude),
title: markers[i].Name + ", "+ markers[i].Address,
draggable: false
});
var statusStr;
//Set marker icon depending upon current stage
switch (markers[i].Stage)
{
//Stage 1 - Brochure
case 5: newMarker.setIcon(stage1MarkerImage);
statusStr = 'Current Status - <select id="status"> <option id="5" value="Brochure" selected="selected">Brochure</option><option id="6" value="Demo">Demo</option><option id="7" value="Site Visit">Site Visit</option><option id="8" value="Lease Approval">Lease Approval</option></select>';
break;
//Stage 2 - Demo
case 6: newMarker.setIcon(stage2MarkerImage);
statusStr = 'Current Status - <select id="status"> <option id="5" value="Brochure" >Brochure</option><option id="6" value="Demo" selected="selected">Demo</option><option id="7" value="Site Visit">Site Visit</option><option id="8" value="Lease Approval">Lease Approval</option></select>';
break;
//Stage 3 - Site Visit
case 7: newMarker.setIcon(stage3MarkerImage);
statusStr = 'Current Status - <select id="status"> <option id="5" value="Brochure" >Brochure</option><option id="6" value="Demo" >Demo</option><option id="7" value="Site Visit" selected="selected">Site Visit</option><option id="8" value="Lease Approval">Lease Approval</option></select>';
break;
//Stage 4 - Lease Approval
case 8: newMarker.setIcon(stage4MarkerImage);
statusStr = 'Current Status - <select id="status"> <option id="5" value="Brochure" >Brochure</option><option id="6" value="Demo" >Demo</option><option id="7" value="Site Visit" ><Site Visit/option><option id="8" value="Lease Approval" selected="selected">Lease Approval</option></select>';
break;
}
newMarker["infoWindow"] = new google.maps.InfoWindow({
content:
'<div class="infoWindow">' +
'<header>' + markers[i].Name + '</header>' +
'<div style="clear: both;"></div>' +
'<div class="content">' +
'<p>' + markers[i].Address + ', ' + markers[i].City + ', ' + markers[i].State + ', ' + markers[i].CountryName + '</p>' +
'<p>' +
statusStr+
'<label id="update-status" onclick="updateCustomerStep(this);" data-id="' + markers[i].Id + '" >Update</label>' +
'</p>' +
'</div>' +
'</div>'
});
google.maps.event.addListener(newMarker, 'click', function() {
for (var i = 0; i < markerArray.length; i++)
{
var currentMarker = markerArray[i];
currentMarker["infoWindow"].close();
console.log(currentMarker);
}
this['infoWindow'].open(map, this);
});
markerArray.push(newMarker);
}
Nooooooooo! Если только одно информационное окно будет открыто одновременно, создайте ONE infoWindow и измените его содержимое всякий раз, когда он будет открыт. –
Что делать, если у вас есть создание и открытие содержимого infowindow из базы данных, скажем, для нескольких магазинов, как оно получит его содержимое, и что, если мне нужно будет изменить значок значка с помощью кнопки содержимого infowindow, будет работать одно из них. Можете ли вы предложить обновления в приведенном выше коде (рабочие), чтобы соответствовать этому решению. –