I have a Google Map with multiple markers. I'm trying to show info in my InfoWindow for each marker:
function initializeMaps() {
var latlng = new google.maps.LatLng(59.4920, 37.3010);
var myOptions = {
zoom: 6,
center: latlng,
disableDefaultUI: false,
scrollwheel: false,
mapTypeId: google.maps.MapTypeId.ROADMAP,
};
var infoWindow = new google.maps.InfoWindow();
var latlngbounds = new google.maps.LatLngBounds();
var map = new google.maps.Map(document.getElementById('map'),myOptions);
var mc = new MarkerClusterer(map);
var marker, i;
for (i = 0; i < data.markers.length; i++) {
var image = "/images/markers/green-marker.png";
marker = new google.maps.Marker({
position: new google.maps.LatLng(data.markers[i].lat, data.markers[i].lng),
map: map,
title: data.markers[i].name,
icon: image,
});
/*jshint loopfunc: true */
(function (marker, data) {
google.maps.event.addListener(marker, "click", function (e) {
for (i=0; i<data.markers.length; i++) {
infoWindow.setContent("<div style = 'min-width:200px;min-height:40px'>" + '<img src="' + data.markers[i].link + '" style="height:150px;width:250px;" />' + "<br />" + data.markers[i].description + "<br />" + "<button>Read More</button>" + "</div>");
infoWindow.open(map, marker);
}
});
})(marker, data);
latlngbounds.extend(marker.position);
mc.addMarker(marker);
}
var bounds = new google.maps.LatLngBounds();
}
But it shows me only last element information of my array on every single marker infoWindow on the map. Below my JSON file:
var data = {
"markers":[
{
"city": "City Sample Text",
"name": "Name Sample Text",
"shortname": "redsquare_location",
"description": "Descr Sample Text",
"lat": "51.4910",
"lng": "31.2985",
"link": "images/infowindows/rs_rp.png",
},
{
"city": "City Sample Text",
"name": "Name Sample Text",
"shortname": "pchurch_location",
"description": "Descr Sample Text",
"lat": "51.4925",
"lng": "31.3007",
"link": "images/infowindows/pc_rp.png",
},
{
"city": "City Sample Text",
"name": "Name Sample Text",
"shortname": "muschool_location",
"description": "Decr Sample Text",
"lat": "51.4932",
"lng": "31.3054",
"link": "images/infowindows/ms_rp.png",
}
]
}
What my mistake is?