我得到了一个apiendpoint,它返回一个数组地址和一些地址的价格信息,但它不返回lat/lang,所以我使用geocode在地图上显示地址的标记,并在每次单击标记时显示infowindow。现在,我希望infowindow的内容是从Endpoint返回的数组中的地址的价格。希望到目前为止一切都很清楚。现在的问题是,每次我单击marker,infowindow只显示每个infowindow上数组的最后(相同)价格,而不显示与该地址相关的价格。请查看下面的代码(或签入fiddlejs=>https://jsfiddle.net/pulxak1k/7/)。可能是我试图在asyn回调中调用sync,所以我尝试在最初的api调用中使用$q.promise和resolve并尝试在内部调用geocode.geocoder。然后,但还没有运气…
<div id="map-canvas"></div>
function initialize() {
var chicago = new google.maps.LatLng(41.850033, -87.6500523);
var mapOptions = {
zoom: 7,
mapTypeId: google.maps.MapTypeId.ROADMAP,
center: chicago
}
map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
geocoder = new google.maps.Geocoder()
var someArray = [{price: 10, address: 'cv64ad'}, {price: 20, address: 'cv59bp'}]
for (var i = 0; i < someArray.length; i++) {
var home = someArray[i]
console.log(home.address)
geocoder.geocode({'address': home.address}, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
map.setCenter(results[0].geometry.location);
map.setZoom(12);
for (var i in results) {
var marker = new google.maps.Marker({
position: new google.maps.LatLng(results[i].geometry.location.A, results[i].geometry.location.F),
map: map
})
google.maps.event.addListener(marker, 'click', someCallback(home))
infowindow = new google.maps.InfoWindow();
function someCallback(home) {
return function (e) {
if (infowindow != null) {
infowindow.close();
}
infowindow.setContent('<div class="infoheading">' + home.price + '</div>');
infowindow.open(map, this);
}
}
}
}
})
}
}
google.maps.event.addDomListener(window, 'load', initialize);
如下所示:https://jsfiddle.net/jvxppeap/2/
诀窍是:创建一个包含标记对象的数组。然后,在addListener(marker,'click'...)中检查单击了哪些标记;查看代码中的“indexof”。使用该索引,您可以读取someArray的正确项,并可以在其中添加任何您想要的信息。
var markers = [];
var map;
var infowindow;
function initialize() {
var chicago = new google.maps.LatLng(41.850033, -87.6500523);
var mapOptions = {
zoom: 7,
mapTypeId: google.maps.MapTypeId.ROADMAP,
center: chicago
}
map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
geocoder = new google.maps.Geocoder();
var someArray = [{price: 10, address: 'cv64ad'}, {price: 20, address: 'cv59bp'}];
for (var i = 0; i < someArray.length; i++) {
var home = someArray[i];
console.log(home.address);
geocoder.geocode({'address': home.address}, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
map.setCenter(results[0].geometry.location);
map.setZoom(12);
for (var i in results) {
var marker = new google.maps.Marker({
position: new google.maps.LatLng(results[i].geometry.location.A, results[i].geometry.location.F),
map: map
});
// push the marker on the markers array
markers.push(marker);
google.maps.event.addListener(marker, 'click', function (home) {
if (infowindow != null) {
infowindow.close();
}
// now, we want to know which of the markers we're talking about
var index = markers.indexOf(this);
infowindow.setContent('<div class="infoheading">' + someArray[index].price + '</div>');
infowindow.open(map, this);
});
infowindow = new google.maps.InfoWindow();
}
}
})
}
}
google.maps.event.addDomListener(window, 'load', initialize);
当我点击google maps标记时,它会注册点击,但我无法在状态改变后显示InfoWindow。 尝试在单击时设置/读取更新的状态 ''' 我期望google map标记会出现某种类型的InfowWindow,但相反,infowWindowOpened返回的是未定义的
嗨,我有问题,如何实现点击标记的信息窗口?问题是我在地图上有很多标记,如果单击信息窗口,每个标记都有另一个活动<代码>在此处输入代码 以下是示例 标记1----- 我尝试了很多代码但没有解决
嗨,我有一个关于android谷歌地图上infowindow的问题。 我想制作一个包含其他菜单的信息窗口。当我点击方向时,谷歌地图就会显示出来,如果我点击另一个文本,就会显示另一个活动。我从goole map javascript中知道这张图片
问题内容: 我正在使用Angular.js应用程序,该应用程序通过医疗程序的json文件进行过滤。当使用ng- click单击(在同一页面上)过程名称时,我想显示每个过程的详细信息。这是我到目前为止的内容,.procedure-details div设置为显示:无: 我在角度上很新。有什么建议? 问题答案: 删除,然后改用: 这是小提琴:http : //jsfiddle.net/asmKj/ 您
我看到人们在这项具体的任务中发现了很多困难,我也需要帮助。 我已经成功地使用Google提供的默认代码在地图上创建了标记。但现在我希望能够点击“InfoWindow”打开一个新的活动,这样我就可以添加更多的信息。 有人知道最好的办法吗? 如果你能回答这个问题,请提供一些代码或一个例子。任何帮助都将不胜感激!