我创建了一个应用程序,用于显示标记的信息窗口弹出窗口,应用程序工作正常,弹出窗口正确显示但唯一的解决方案是在鼠标悬停时自定义信息窗口弹出窗口,默认弹出窗口html标签显示如下所示。
任何人都可以告诉我一些解决方案吗
我的代码如下所示
var infowindow = new google.maps.InfoWindow();
function point(name, lat, long) {
var self = this;
self.name = name;
var marker = new google.maps.Marker({
position: new google.maps.LatLng(lat, long),
title: name,
map: map,
draggable: true
});
google.maps.event.addListener(marker, 'mouseover', function () {
infowindow.setContent(marker.title);
infowindow.open(map, marker);
}.bind(this));
google.maps.event.addListener(marker, 'mouseout', function () {
infowindow.close();
}.bind(this));
}
var map = new google.maps.Map(document.getElementById('googleMap'), {
zoom: 5,
center: new google.maps.LatLng(55, 11),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var viewModel = {
points: ko.observableArray([
new point('<div>Test1<br>Test5</div>', 55, 11),
new point('Test2', 56, 12),
new point('Test3', 57, 13)])
};
function addPoint() {
console.log(viewModel.points().length);
for (var i = 0; i < viewModel.points().length; i++)
{
console.log(i);
console.log(viewModel.points().marker.title);
}
viewModel.points.push(new point('a', 58, 14));
}
ko.applyBindings(viewModel);
答案 0 :(得分:2)
您可以手动删除title
上的元素mouseover
属性。
尝试更改
google.maps.event.addListener(marker, 'mouseover', function () {
要
google.maps.event.addListener(marker, 'mouseover', function (e) {
e.ya.target.removeAttribute('title');
同样适用于Edge
,您需要将其更改为:
e.ya.target.parentElement.removeAttribute('title')
答案 1 :(得分:0)
我一直在利用这个线程处理几乎相同的问题。当单击标记时,我可以使用Google Maps API在弹出显示中正确显示欧洲重音字形,但鼠标悬停时未正确呈现相同的编码文本字符串。
因此,在查看了JSFiddle中有用的代码示例,并且无法使用该建议的技术删除“标题”文本之后,最终我清楚地了解了Mr.Upsidown在他认为我们可能只是更改了显示为标题的属性的名称。我没有意识到保留属性'title'的定义是“要在悬停时显示的文本”。因此,最简单的解决方案是在标记选项列表中使用诸如“myTitle”之类的属性。当没有title属性时,悬停变为非事件。
答案 2 :(得分:0)
似乎标记的标题设置为弹出窗口的html内容。 创建标记对象时,为其提供标题属性,该属性将显示您想要显示的内容(即您所在位置的名称...)
var marker = new google.maps.Marker({
position: whateverpositionyouset,
title: whatevertitleyouwant,
map: map
})