javascript – 关闭Google Maps API v3中的所有信息窗口

我忙于一个脚本,将在我的网站上创建一个google地图画布,有多个标记。我想要当你点击一个标记,一个信息窗口打开。我做到了,代码是在这一刻:

 var latlng = new google.maps.LatLng(-34.397, 150.644);
    var myOptions = {
      zoom: 8,
      center: latlng,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    };
    var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    function addMarker(map, address, title) {
     geocoder = new google.maps.Geocoder();
     geocoder.geocode( { 'address': address}, function(results, status) {
        if (status == google.maps.GeocoderStatus.OK) {
          map.setCenter(results[0].geometry.location);
          var marker = new google.maps.Marker({
     position: results[0].geometry.location,
              map: map,
              title:title
    });
    google.maps.event.addListener(marker, 'click', function() {
     var infowindow = new google.maps.InfoWindow();
            infowindow.setContent('<strong>'+title + '</strong><br />' + address);
             infowindow.open(map, marker);

          });
        } else {
          alert("Geocode was not successful for the following reason: " + status);
        }
     });
    }
    addMarker(map, 'Address', 'Title');
 addMarker(map, 'Address', 'Title');

这工作100%。但现在我想要当一个信息窗口打开,你想打开第二个,第一个自动关闭。但我没有找到办法做到这一点。 infowindow.close();不会帮助。有人有一个例子或解决这个问题吗?

infowindow是局部变量,窗口​​在close()时不可用。

var latlng = new google.maps.LatLng(-34.397, 150.644);
var infowindow = null;

...

google.maps.event.addListener(marker, 'click', function() {
    if (infowindow) {
        infowindow.close();
    }
    infowindow = new google.maps.InfoWindow();
    ...
});
...
翻译自:https://stackoverflow.com/questions/4539905/close-all-infowindows-in-google-maps-api-v3

转载注明原文:javascript – 关闭Google Maps API v3中的所有信息窗口