1

原文地址 点这

# google地图点击弹出InfoWindow,同时关闭上一个InfoWindow

因为项目需求原因,需要实现以下功能:
- 点击地图上的每个坐标标记后显示其坐标信息
- 当有多个点时,地图上只能存在一个infowindow
解决思路如下:
首先给出google地图infowindow的一个示例用法(https://developers.google.com/maps/documentation/javascript/examples/event-closure?hl=zh-cn
示例中为每个坐标点添加了点击事件,弹出一个infowindow,在此窗口上显示信息,具体不在赘述,示例中得源码很简单。
可是我们会发现,当我们点击一个点弹出infowindow,然后不去手动关闭,在点击下一个点时,先前的那个ingowindow仍然留在地图上,当点击的很多时,就会是这种效果了:

相信这会让使用这套系统的人疯掉的,那么如何解决这个问题呢?很简单,每当我们打开一个新的infowindow时就关闭上一个infowindow,查询google地图API,发现infowindow给开发人员提供了close()这个方法,这下一切事情就好办了。解决思路:
首先需要一个存取infowindow的数组,还有一个存储上一个infowindow的索引,分别取名为infowindows和lastindex=-1;然后,每当new一个infowindow时,将其存入infowindows,在为坐标点添加点击事件时,首先检查索引值,若为-1,则跳出if语句,若不为-1,则将该索引下的infowindow关闭,之后打开新的infowindow,并将新的索引值附给lastindex,方便下一次点击事件的执行,Demo和代码如下:

var infowindows = [];
var lastIndex=-1;  
//marker是一个坐标标记点
//只需在一个marker数组的每一次循环添加时调用即可
function addMessage(marker) {
                var message="hello"             
                var infowindow = new google.maps.InfoWindow({
                    content : message
                });

                infowindows.push(infowindow);

                google.maps.event.addListener(marker, 'click', function() {
                    if(lastIndex!=-1)
                        {
                          infowindows[lastIndex].close();
                        }
                    infowindow.open(marker.get('map'), marker); 
                        lastIndex=infowindows.indexOf(infowindow,0);
                });
            }  

么西期待你的看法和意见,欢迎交流


十四
2k 声望61 粉丝

背着元编程上学放学的男孩