google maps api v3 массив infoBubble не работает
У меня есть карта, которая использует infoBubble.js.
На этой карте есть множество мест, через которые я итерирую.
InfoBubble должен появиться при нажатии на пользовательский значок, но по какой-то причине он открывает только первый элемент данных.
У кого-нибудь есть идея относительно того, почему это может произойти?
Я разработал код для этого здесь;
var arrMarkers = [
['Santiago de Cuba', 20.040450354169483, -75.8331298828125],
['Las Tunas', 20.97682772467435, -76.9482421875],
['Camaguey', 21.39681937408218, -77.9205322265625],
['Playa Santa Lucia', 21.555284406923192, -77.0526123046875],
['Santa Clara', 22.421184710331854, -79.9639892578125],
['Cienfuegos', 22.161970614367977, -80.4473876953125],
['Havana', 23.12520549860231, -82.3919677734375],
['San Cristobel', 22.730590425493833, -83.045654296875],
['Pinar del Rio', 22.43641760076311, -83.69384765625]
];
var arrInfoWindowsCuba = [];
var arrInfoWindows = [];
arrMarkers[i] = marker;
function init() {
var mapCenter = new google.maps.LatLng(21.616579336740603, -78.892822265625);
map = new google.maps.Map(document.getElementById('map_canvas'), {
zoom: 7,
center: mapCenter,
mapTypeId: google.maps.MapTypeId.TERRAIN
});
var image = '/wp-content/themes/Shootcuba/images/map-icon.png';
for (i = 0; i < arrMarkers.length; i++) {
var marker = new google.maps.Marker({
map: map,
position: new google.maps.LatLng(arrMarkers[i][1], arrMarkers[i][2]),
icon: image
});
var infoBubble = new InfoBubble({
content: '<div class="phoneytext">' + arrMarkers[i][0] + '<div class="left-col2"></div></div>',
boxClass: 'info-box',
alignBottom: true,
pixelOffset: new google.maps.Size(-150, -40),
maxWidth: 300,
padding: 0,
closeBoxMargin: '0px',
borderColor: '#ffffff',
borderRadius: '0',
maxWidth: 535,
disableAutoPan: false,
hideCloseButton: false,
backgroundClassName: 'phoney'
});
google.maps.event.addListener(marker, 'click', function () {
infoBubble.open(map, marker, i);
console.log(arrMarkers);
});
arrMarkers[i] = marker;
arrInfoWindowsCuba[i] = infoBubble;
}
}
1 ответ
Вот рабочий пример. Я вынул несколько массивов, которые у вас были (я не был полностью уверен, для чего они все предназначены, и они вызывали ошибки только в фрагменте, который вы опубликовали), но в остальном это довольно верно для того, что вы делали. Большая разница в том, что я сделал отдельную функцию для создания маркеров. В основном это было сделано для того, чтобы область событий щелчка была отделена друг от друга, поскольку событие щелчка, всегда запускающее последнее событие, указывает мне, что области не разделены должным образом.
В частности, я считаю, что происходило то, что функция события, в которой вы переопределяли значения для marker и infoBubble, и прослушиватель событий будут ссылаться на текущие значения этих переменных, а не на значения при первом подключении слушателя. Выполнение отдельного вызова функции для поддержания контекста событий кажется мне самым чистым решением.