我有一个shop
型号。我想输出一个简单的警告框,当我点击地图上商店的标记时,使用javascript显示shop
名称。
这是我的代码:
# controller
@json = Shop.all.to_gmaps4rails do |shop, marker|
marker.json({ id: shop.id, name: shop.name })
end
# view
<%= gmaps("map_options" => { auto_zoom: false, zoom: 2, class: "homepage-map" },
"markers" => { data: @json,
options: { do_clustering: true,
clusterer_maxZoom: 11,
raw: "{ animation: google.maps.Animation.DROP }" }
})
%>
<% content_for :scripts do %>
<script type="text/javascript" charset="utf-8">
Gmaps.map.callback = function() {
for (var i = 0; i < this.markers.length; ++i) {
google.maps.event.addListener(Gmaps.map.markers[i].serviceObject, 'click', function() {
alert(put something here);
});
}
};
</script>
<% end %>
这是我第一次与json打交道,所以我已经阅读了一些关于json和json in javascript的介绍性文章。我想知道如何使用gmaps4rails完成这项工作。
答案 0 :(得分:1)
这应该可以解决问题:
<script type="text/javascript" charset="utf-8">
function handleMarkerClickClosure(marker) {
return function() {
alert(marker.name);
}
}
Gmaps.map.callback = function() {
for (var i = 0; i < this.markers.length; ++i) {
google.maps.event.addListener(Gmaps.map.markers[i].serviceObject, 'click', handleMarkerClickClosure(Gmaps.map.markers[i]) );
}
};
</script>