1
我已嚴格按照Google開發人員documentation執行了地點搜索框。標記將根據特定的搜索詞顯示在地圖上(例如「餐館」)。當然,當用戶點擊某個標記時,我想要顯示一個infowindow,以便向用戶提供有關該地點的一些信息。我跟蹤Google開發者documentation以激活infowindows,但沒有取得任何成功(我在代碼中所做的更改由註釋1,2和3說明)。 Google Maps API Javascript:激活地點搜索框中標記的infowindows
此前的帖子並沒有幫助我。任何幫助將不勝感激。
<script>
function initMap() {
var map = new google.maps.Map(document.getElementById('map'), {
center: {lat: -33.8688, lng: 151.2195},
zoom: 13,
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var input = document.getElementById('pac-input');
var searchBox = new google.maps.places.SearchBox(input);
map.controls[google.maps.ControlPosition.TOP_LEFT].push(input);
map.addListener('bounds_changed', function() {
searchBox.setBounds(map.getBounds());
});
// 1: Variables infowindow and service:
var infowindow = new google.maps.InfoWindow();
var service = new google.maps.places.PlacesService(map);
var markers = [];
searchBox.addListener('places_changed', function() {
var places = searchBox.getPlaces();
if (places.length == 0) {
return;
}
markers.forEach(function(marker) {
marker.setMap(null);
});
markers = [];
var bounds = new google.maps.LatLngBounds();
places.forEach(function(place) {
var icon = {
url: place.icon,
size: new google.maps.Size(71, 71),
origin: new google.maps.Point(0, 0),
anchor: new google.maps.Point(17, 34),
scaledSize: new google.maps.Size(25, 25)
};
markers.push(new google.maps.Marker({
map: map,
icon: icon,
title: place.name,
position: place.geometry.location
}));
if (place.geometry.viewport) {
bounds.union(place.geometry.viewport);
} else {
bounds.extend(place.geometry.location);
}
});
// 2: getDetails, referring to the "places" (var places = searchBox.getPlaces();) already on the map
// 3: addlistener on the markers, to show an infowindow upon a clickevent
service.getDetails(places, function(place, status) {
if (status === google.maps.places.PlacesServiceStatus.OK) {
google.maps.event.addListener(markers, 'click', function() {
infowindow.setContent('<div><strong>' + place.name + '</strong><br>' +
'Place ID: ' + place.place_id + '<br>' +
place.formatted_address + '</div>');
infowindow.open(map, this);
});
}
});
map.fitBounds(bounds);
});
}
</script>