0

我地图上的每个标记都有一个信息窗口。

如果我使用 Infobox 插件来构建信息窗口,它内部的远程链接会将操作处理为“HTML”而不是“JS”。

当我删除 infoboxBuilder 时,我应该指出一切正常(我的意思是,动作被处理为“JS”)。

我的代码:

var handler = Gmaps.build('Google', {builders: { Marker: InfoBoxBuilder} });

# In the Infowindow : <%= link_to "More", voir_infos_path(t), :remote => true %>
# Log : Started GET "/voir_infos/545e1dd382cd47db98000bb9" for 127.0.0.1 at 2014-12-04 23:10:56 +0100
Processing by ObjetsController#voir_infos as HTML

但是当我删除 InfoBoxBuilder 时:

var handler = Gmaps.build('Google');
# Same code in Infowindow : <%= link_to "More", voir_infos_path(t), :remote => true %>
# Log : Started GET "/voir_infos/545e23ae82cd47e5ac000542" for 127.0.0.1 at 2014-12-04 23:13:53 +0100
Processing by ObjetsController#voir_infos as JS

这是infoboxbuilder.js.coffee我在stackoverflow上找到的:

class @InfoBoxBuilder extends Gmaps.Google.Builders.Marker # inherit from base builder
# override method
create_infowindow: ->
   return null unless _.isString @args.infowindow

boxText = document.createElement("div")
boxText.setAttribute("class", 'yellow') #to customize
boxText.innerHTML = @args.infowindow
@infowindow = new InfoBox(@infobox(boxText))

@bind_infowindow() 

infobox: (boxText)->
  content: boxText
  boxClass: "infoBox box-shadow"
  pixelOffset: new google.maps.Size(-140, -380)
  closeBoxURL: ""
  boxStyle:
    width: "280px"

我怎样才能使它工作?谢谢

编辑

我在每个 Infowindow 中都有这个链接:<%= link_to "More", voir_infos_path(t), :remote => true %>它应该将 ObjetsController#voir_infos 处理为“JS”,不是吗?

当我使用 Infobox 插件显示信息窗口时(使用这部分代码:builders: { Marker: InfoBoxBuilder} 并单击“更多”,:remote => true不起作用,并且 ObjetsController#voir_infos 被处理为“HTML”而不是“JS”。

当我删除builders: { Marker: InfoBoxBuilder}时,一切正常,当我点击“更多”时,ObjetsController#voir_infos 被处理为“JS”。

编辑 2:

为 Infowindow 生成的 HTML:

<div class="infoBox box-shadow" style="width: 280px; position: absolute; visibility: visible; left: 132.270229334012px; top: 72.179231562186px; cursor: default;"><div class="yellow"><div class="row iw-content">
<div>
    <img src="/covers/max_creer/missing.png">
</div>
<div class="small-12 columns">
    <div class="row">
        <div class="small-12 columns">
            <h6> Maison Bloc </h6>

        </div>

    </div>
    <div class="row">
        <div class="small-12 columns">
            <a href="/voir_infos/545e1de582cd47db98000d91"  data-remote="true">More</a>
        </div>
    </div>
</div>

4

0 回答 0