【发布时间】:2010-12-24 22:32:27
【问题描述】:
我只需要在我的 Google 地图上打开一个信息窗口。在打开新的 InfoWindows 之前,我需要关闭所有其他 InfoWindows。
谁能告诉我怎么做?
【问题讨论】:
-
你尝试了什么?
标签: javascript google-maps google-maps-api-3
我只需要在我的 Google 地图上打开一个信息窗口。在打开新的 InfoWindows 之前,我需要关闭所有其他 InfoWindows。
谁能告诉我怎么做?
【问题讨论】:
标签: javascript google-maps google-maps-api-3
Google 地图只允许您打开一个信息窗口。因此,如果您打开一个新窗口,那么另一个窗口会自动关闭。
【讨论】:
您需要跟踪您之前的@987654321@ 对象并在处理新标记上的点击事件时对其调用close 方法。
注意 不需要在共享信息窗口对象上调用 close,使用不同的标记调用 open 将自动关闭原始对象。详情请见Daniel's answer。
【讨论】:
close() 方法,如果使用单个 InfoWindow 对象.如果在同一对象上再次调用open() 方法,它将自动关闭。
在范围之外创建您的信息窗口,以便您可以共享它。
这是一个简单的例子:
var markers = [AnArrayOfMarkers];
var infowindow = new google.maps.InfoWindow();
for (var i = 0, marker; marker = markers[i]; i++) {
google.maps.event.addListener(marker, 'click', function(e) {
infowindow.setContent('Marker position: ' + this.getPosition());
infowindow.open(map, this);
});
}
【讨论】:
您只需要创建一个InfoWindow 对象,保留对它的引用,并为所有标记重复使用 if。 Quoting from the Google Maps API Docs:
如果您希望一次只显示一个信息窗口(就像 Google 地图上的行为一样),您只需创建一个信息窗口,您可以根据地图事件(例如用户点击)将其重新分配给不同的位置或标记)。
因此,您可能只想在初始化地图后创建InfoWindow 对象,然后按如下方式处理标记的click 事件处理程序。假设您有一个名为 someMarker 的标记:
google.maps.event.addListener(someMarker, 'click', function() {
infowindow.setContent('Hello World');
infowindow.open(map, this);
});
那么InfoWindow 应该会在您单击新标记时自动关闭,而无需调用close() 方法。
【讨论】:
我遇到了同样的问题,但最好的答案并没有完全解决它,我在 for 语句中必须做的是使用与我当前标记相关的 this。也许这对某人有帮助。
for(var i = 0; i < markers.length; i++){
name = markers[i].getAttribute("name");
address = markers[i].getAttribute("address");
point = new google.maps.LatLng(parseFloat(markers[i].getAttribute("lat")), parseFloat(markers[i].getAttribute("lng")));
contentString = '<div style="font-family: Lucida Grande, Arial, sans-serif;>'+'<div><b>'+ name +'</b></div>'+'<div>'+ address +'</div>';
marker = new google.maps.Marker({
map: map,
position: point,
title: name+" "+address,
buborek: contentString
});
google.maps.event.addListener(marker, 'click', function(){
infowindow.setContent(this.buborek);
infowindow.open(map,this);
});
marker.setMap(map);
}
【讨论】:
基本上,您需要一个函数来保持对一个 new InfoBox() 的引用 => 委托 onclick 事件。
在创建标记时(在循环中)使用bindInfoBox(xhr, map, marker);
// @param(project): xhr : data for infoBox template
// @param(map): object : google.maps.map
// @param(marker): object : google.maps.marker
bindInfoBox: (function () {
var options = $.extend({}, cfg.infoBoxOptions, { pixelOffset: new google.maps.Size(-450, -30) }),
infoBox = new window.InfoBox(options);
return function (project, map, marker) {
var tpl = renderTemplate(project, cfg.infoBoxTpl); // similar to Mustache, Handlebars
google.maps.event.addListener(marker, 'click', function () {
infoBox.setContent(tpl);
infoBox.open(map, marker);
});
};
}())
var infoBox 被异步分配并保存在内存中。每次调用 bindInfoBox() 时,都会调用 return 函数。也很方便通过infoBoxOptions 一次!
在我的示例中,我不得不向 map 添加一个额外的参数,因为我的初始化被选项卡事件延迟了。
【讨论】:
有点晚了,但我设法通过将 infowindow 设为全局变量打开了一个 infowindow。
var infowindow = new google.maps.InfoWindow({});
然后在监听器中
infowindow.close();
infowindow = new google.maps.InfoWindow({
content: '<h1>'+arrondissement+'</h1>'+ gemeentesFiltered
});
infowindow.open(map, this);
【讨论】:
声明一个 globar var selectedInfoWindow; 并使用它来保存打开的信息窗口:
var infoWindow = new google.maps.InfoWindow({
content: content
});
// Open the infowindow on marker click
google.maps.event.addListener(marker, "click", function() {
//Check if there some info window selected and if is opened then close it
if (selectedInfoWindow != null && selectedInfoWindow.getMap() != null) {
selectedInfoWindow.close();
//If the clicked window is the selected window, deselect it and return
if (selectedInfoWindow == infoWindow) {
selectedInfoWindow = null;
return;
}
}
//If arrive here, that mean you should open the new info window
//because is different from the selected
selectedInfoWindow = infoWindow;
selectedInfoWindow.open(map, marker);
});
【讨论】:
这样解决了:
function window(content){
google.maps.event.addListener(marker,'click', (function(){
infowindow.close();
infowindow = new google.maps.InfoWindow({
content: content
});
infowindow.open(map, this);
}))
}
window(contentHtml);
【讨论】:
这是一种无需创建一个 infoWindow 即可重复使用的解决方案。您可以继续创建许多 infoWindows,您唯一需要的是构建一个 closeAllInfoWindows 函数,并在打开新的 infowindow 之前调用它。 因此,保留您的代码,您只需要:
创建一个全局数组来存储所有的infoWindows
var infoWindows = [];
将每个新的 infoWindow 存储在数组中,紧随 infoWindow = new...
infoWindows.push(infoWindow);
创建 closeAllInfoWindows 函数
function closeAllInfoWindows() {
for (var i=0;i<infoWindows.length;i++) {
infoWindows[i].close();
}
}
在您的代码中,在打开 infoWindow 之前调用 closeAllInfoWindows()。
问候,
【讨论】:
使用 jQuery 实现此目的的一种智能简单的方法如下:
google.maps.event.addListener(marker, 'click', function (e) {
jQuery(".gm-ui-hover-effect").click();
marker.info.open(map, this);
});
它将单击工具提示中的所有关闭按钮。
【讨论】: