- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
希望有好心人可以帮助我。我没有足够的 google api 和 jquery 知识来实现我所需要的。
我有一个谷歌地图,你可以在这里看到演示 http://divinethemes.eu/map/该脚本与信息框配合使用,每个点都按类别等进行过滤。
我需要的是能够从外部 map 列表(来自 HTML)提供一些操作:打开特定点的气泡(并关闭已打开的 + 使 map 居中)或弹起气泡或突出显示具体标记。我的目的是创建一个类似(更简单)的谷歌地图位置列表,如 Airbnb。如果在 map 外部的 HTML 列表中,每个点都可以是通过 id 或数据属性打开特定气泡的 href,比如“name_point”,那就太好了。但我不知道该怎么做...
这是 map 的代码:
(function(A) {
if (!Array.prototype.forEach)
A.forEach = A.forEach || function(action, that) {
for (var i = 0, l = this.length; i < l; i++)
if (i in this)
action.call(that, this[i], i, this);
};
})(Array.prototype);
var
mapObject,
markers = [],
markersData = {
'Bars': [
{
type_point: 'Wine bar',
location_latitude: 43.773781,
location_longitude: 11.257206,
map_image_url: 'img/thumb_map_2.jpg',
rate: 'Superb 7.5',
name_point: 'Astor Cafe',
description_point: 'Piazza del Duomo, 20/R',
get_directions_start_address: '43.773460, 11.255985',
phone: '+3934245255',
url_detail: 'single_tour.html'
},
{
type_point: 'Pub - Wine bar',
location_latitude: 43.772238,
location_longitude: 11.252205,
map_image_url: 'img/thumb_map_3.jpg',
rate: 'Superb 7.5',
name_point: 'Uncle Jimmy',
description_point: 'Via dei Pescioni,10',
get_directions_start_address: '43.773460, 11.255985',
phone: '+3934245255',
url_detail: 'single_tour.html'
}
]
};
var mapOptions = {
zoom: 16,
center: new google.maps.LatLng(43.773460, 11.255985),
mapTypeId: google.maps.MapTypeId.ROADMAP,
mapTypeControl: false,
mapTypeControlOptions: {
style: google.maps.MapTypeControlStyle.DROPDOWN_MENU,
position: google.maps.ControlPosition.LEFT_CENTER
},
panControl: false,
panControlOptions: {
position: google.maps.ControlPosition.TOP_RIGHT
},
zoomControl: true,
zoomControlOptions: {
style: google.maps.ZoomControlStyle.LARGE,
position: google.maps.ControlPosition.TOP_RIGHT
},
scrollwheel: false,
scaleControl: false,
scaleControlOptions: {
position: google.maps.ControlPosition.TOP_LEFT
},
streetViewControl: true,
streetViewControlOptions: {
position: google.maps.ControlPosition.LEFT_TOP
},
};
var marker;
mapObject = new google.maps.Map(document.getElementById('map'), mapOptions);
for (var key in markersData)
markersData[key].forEach(function (item) {
marker = new google.maps.Marker({
position: new google.maps.LatLng(item.location_latitude, item.location_longitude),
map: mapObject,
icon: 'img/pins/' + key + '.png',
});
if ('undefined' === typeof markers[key])
markers[key] = [];
markers[key].push(marker);
google.maps.event.addListener(marker, 'click', (function () {
closeInfoBox();
getInfoBox(item).open(mapObject, this);
mapObject.setCenter(new google.maps.LatLng(item.location_latitude, item.location_longitude));
}));
});
function hideAllMarkers () {
for (var key in markers)
markers[key].forEach(function (marker) {
marker.setMap(null);
});
};
function closeInfoBox() {
$('div.infoBox').remove();
};
function getInfoBox(item) {
return new InfoBox({
content:
'<div class="marker_info" id="marker_info">' +
'<img src="' + item.map_image_url + '" alt=""/>' +
'<span>'+
'<span class="infobox_rate">'+ item.rate +'</span>' +
'<h3>'+ item.name_point +'</h3>' +
'<em>'+ item.type_point +'</em>' +
'<strong>'+ item.description_point +'</strong>' +
'<a href="'+ item.url_detail + '" class="btn_infobox_detail"></a>' +
'<form action="http://maps.google.com/maps" method="get" target="_blank"><input name="saddr" value="'+ item.get_directions_start_address +'" type="hidden"><input type="hidden" name="daddr" value="'+ item.location_latitude +',' +item.location_longitude +'"><button type="submit" value="Get directions" class="btn_infobox_get_directions">Get directions</button></form>' +
'<a href="tel://'+ item.phone +'" class="btn_infobox_phone">'+ item.phone +'</a>' +
'</span>' +
'</div>',
disableAutoPan: true,
maxWidth: 0,
pixelOffset: new google.maps.Size(35, -175),
closeBoxMargin: '5px -28px 0 0',
closeBoxURL: "img/close_infobox.png",
isHidden: false,
pane: 'floatPane',
enableEventPropagation: true
});
};
最佳答案
看来您在 markers
数组中保留了所有标记的引用。您可以在任何标记上触发 click
事件来模拟点击它。这样,信息框将打开以进行标记, map 将在那里居中。
因此,创建一个如下函数:
function onHtmlClick(key){
google.maps.event.trigger(markers[key], "click");
}
其中key
是您想要在markers
数组中弹出的标记的索引。
在您的 html 元素上,您只需调用该函数,例如:
<div onclick="onHtmlClick(1)">...</div>
编辑!
看起来在您的代码中,markers
数组具有以下结构:
[ LOCATION_TYPE_1: [ MARKER, MARKER,..], LOCATION_TYPE_2: [ MARKER4, MARKER,..]
这意味着您必须更新 onclick
监听器和函数:
<div onclick="onHtmlClick('Bars', 1)">...</div>
function onHtmlClick(location_type, key){
google.maps.event.trigger(markers[location_type][key], "click");
}
工作 fiddle :https://jsfiddle.net/mow89utv/2/
关于javascript - 谷歌地图列表类似于 Airbnb,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37616274/
是否有一种 STL 算法允许我将一个函数应用于一个范围内的每个元素,转换元素,并将之前转换的元素作为输入? 我在想这样的事情(显然行不通,因为第二个迭代器将无效): struct Input {
我有一个字典列表,例如: l =[{country:'Italy',sales:100,cost:50}{country:'Italy',sales:130,cost:60} {co
考虑以下几点: $var = 'Now is the time' if ($var -like 'Now*') { 'true' } else { 'false' } 输出:真 现在交换 -like
我认为这是一个简单的问题,但尚未得到解决方案。我只想从此处解释的列中获取有效数字。 假设我们有一个包含以下值的 varchar 列 ABC Italy Apple 234.62 2:234:43:22
这个问题已经有答案了: MySQL LIKE IN()? (12 个回答) 已关闭 4 年前。 是否可以使用 IN 子句扩展 LIKE 表达式? 此时我得到以下 SQL: select * from
这个问题在这里已经有了答案: How to postpone/defer the evaluation of f-strings? (14 个答案) 关闭 3 年前。 考虑字符串 string_0
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我刚刚阅读了以下关于同一主题的帖子: Facebook like notifications tracking (DB Design)和 Database design to store notifi
我如何在 javascript 中创建一个新事件/像在 c# 中一样? private event EventHandler asdCompleted; private void SetEventHa
我经常访问一个名为 GOOD 的网站我特别喜欢一种审美风格;导航栏如何在网站背景中扩展其颜色。如果您访问该网站,就会明白我的意思。 在 CSS 中,我怎样才能以最简单的方式复制它?我已经用 z-ind
我对 LINQ 比较陌生,不知道如何执行 Like 条件。我有一个 myObject 的 IEnumerable 列表,想要做一些类似 myObject.Description 的事情,比如“Help
我正在尝试在 Sharepoint 2013 提供商托管的应用程序中构建一个类似人员选择器的工具。最初,我使用的是 Utility.ResolvePrincipal,它让我可以访问 Sharepoin
过去几个月我一直在研究微服务架构应用程序,我仍在努力适应分布式特性。我多次注意到一种模式,但我不确定处理它的首选方式是什么。 假设我们有服务 A、服务 B 和服务 C。服务 A 公开了一个 API,其
这个问题在这里已经有了答案: Equivalent to unix "less" command within R console (5 个回答) 6年前关闭。 R 控制台中是否有任何命令与 Linu
是否可以在 Xcode 中为类似于 emacs 中的“标记”功能的行添加书签?还有我可以用来跳转到行号的快捷方式吗?我的源代码变得很长且难以导航。 最佳答案 是的;如果您将文本插入符号放在要添加书签的
在使用 vi 15 年的大部分时间后,我在使用 Go 时一时兴起尝试了 Rob Pike 的 Acme。我真的很喜欢它的小巧轻便。现代 unix 风格的东西在 Acme 中表现不佳,而 Ruby 开发
我正在寻找可以打印矩阵[1:5, 1:5] 的任何包中的函数。 head() 适用于列数较少但矩阵较大的用户。我知道我可以为它创建自己的函数,但我想知道是否已经有函数了。 最佳答案 在名为futile
我正在用 C++ 构建一个聚类算法,但我不能很好地处理 OOP 和发生变化的变量(成员数据)的状态。对于某种复杂的算法,我发现这是我发展的障碍。 因此,我正在考虑将编程语言更改为一种功能语言:Ocam
我有一个这样的日志: Jun 21 06:25:07 172.25.1.1 kernel: DROP IN=ppp0 OUT= MAC= SRC=206.221.177.2 DST=185.79.95
我需要一些帮助来制作类似于 Accordion 的东西。目标是,如果您单击导航中的链接,一个部分会消失,而您单击的部分会出现(在相同位置且不明显)。 如果可能,它还应该自动滚动到该部分的开头(导航的结
我是一名优秀的程序员,十分优秀!