Googlemaps遇到了以下问题。
我创建了一个createMarker函数,它返回一个我用addOverlay()
发布的标记。这样做很完美,标记显示但唯一的问题是标记的点击事件,我想要一个填充了'我想要发布这个文本'文本的信息窗口,而是填充一个名为html的var我在我的代码(var html = 'test';
)的开头设置,我之前收到的'html未定义'的消息,这就是设置html var的原因。每个infowindow都有文本'test'。我尝试过使用updateInfoWindow()
,但这不起作用,有人熟悉这个问题吗?我可以为您提供完整的资源,但我认为createMarker功能应该足够了。
function GM_load() {
map = new GMap2(document.getElementById("map"));
map.addControl(new GSmallMapControl());
map.addControl(new GMapTypeControl());
map.enableScrollWheelZoom();
map.setMapType(G_HYBRID_MAP);
geocoder = new GClientGeocoder();
GM_showItems();
}
function GM_showItems() {
GDownloadUrl("modules/Googlemaps/ajax/getItems.php", function(data, responseCode) {
var xml = GXml.parse(data);
var markers = xml.documentElement.getElementsByTagName("marker");
for (var i = 0; i < markers.length; i++) {
//start
var itemid = markers[i].getAttribute('id');
var title = markers[i].getAttribute('name');
var address = markers[i].getAttribute('address');
var city = markers[i].getAttribute('city');
var x = 0;
if (geocoder) {
geocoder.getLatLng(address + ' ' + city,
function(point) {
if (!point) {
alert(address + ' ' + city + " not found");
} else {
x = x+1;
Marker = createMarker(point, x);
map.addOverlay(Marker);
}
}
);
}
}
});
}
function createMarker(latlng, number) {
var marker = new GMarker(latlng);
marker.value = number;
GEvent.addListener(marker,"click", function() {
map.openInfoWindowHtml(latlng,'i want this text to be published');
});
return marker;
}
答案 0 :(得分:0)
解决。
我覆盖var html。不完美,但它有效。