1
Я установил простой интерфейс Google Map с помощью Google Map API v3 и хочу реализовать функцию, которая может переключаться с маркеров, но она не работает должным образом. Я не могу включить его после выключения слоя.Можно только один раз переключать маркер в API карт Google v3
var request;
var places;
var map;
var markers = [];
var myLatLng = {lat: 34, lng: 38};
// load database and parse into entries
if (window.XMLHttpRequest) {
request = new XMLHttpRequest();
} else {
request = new ActiveXObject("Microsoft.XMLHTTP");
}
request.open('GET', 'places.json');
request.onreadystatechange = function() {
if ((request.readyState ===4) && (request.status===200)) {
places = JSON.parse(request.responseText);
initMap();
console.log(places);
}
}
request.send();
function initMap() {
// map options
var mapOptions = {
zoom: 6,
center: myLatLng,
mapTypeControl: true,
mapTypeId: google.maps.MapTypeId.HYBRID
};
// initialise the map
var map = new google.maps.Map(document.getElementById('map'), mapOptions);
// add markers
for (var i = 0; i < places.length; i++) {
// the place
var place = places[i];
// place co-ordinates
var latlng = new google.maps.LatLng(place.latitude, place.longitude);
var marker = new google.maps.Marker({
position: latlng,
map: map,
title: place.city
});
markers.push(marker);
var infowindow = new google.maps.InfoWindow;
google.maps.event.addListener(marker, 'click', (function(marker){
return function() {
infowindow.open(map,marker);
};
})(marker));
}
}
function toggleMarkers() {
for (var i = 0; i < markers.length; i++) {
if (markers[i].getMap() === null) {
markers[i].setMap(map);
} else {
console.log(markers[0].setMap())
markers[i].setMap(null);
}
}
}
Функция ToggleMarkers вызывается в HTML.
<!DOCTYPE html>
<head>
<!-- scripts -->
<script src="script2.js"></script>
<script src="https://maps.googleapis.com/maps/api/js?v=3&sensor=false&key="API Key"&callback=initMap"></script>
</head>
<body>
<div id="panel">
<button onclick="toggleMarkers()">Toggle Markers</button>
</div>
<div id="map"></div>
</body>
</html>
Где вы добавляете маркеры в массив 'markers'? – geocodezip
В размещенном коде есть ошибки javascript ('Uncaught ReferenceError: content not defined'). Просьба представить [Минимальный, полный, проверенный и читаемый пример] (http://stackoverflow.com/help/mcve), который демонстрирует проблему. – geocodezip
@geocodezip, извините за свои ошибки, я просто обновил файл, но он работает только один раз. – Victor