1

我对将脚本标签放在我的 Rails 应用程序中的确切位置以在页面中嵌入 Google 地图感到困惑。我正在遵循 Google API https://developers.google.com/maps/documentation/javascript/tutorial的指示

代码如下所示:

<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map-canvas { height: 100% }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?key=AIzaSyAK04aYSxZArPElFFZfo3o2p-CbviPzfhc&sensor=false">
    </script>
    <script type="text/javascript">
      function initialize() {
        var mapOptions = {
          center: new google.maps.LatLng(-34.397, 150.644),
          zoom: 8,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map-canvas"),
            mapOptions);
      }
      google.maps.event.addDomListener(window, 'load', initialize);
    </script>
  </head>
  <body>
    <div id="map-canvas"/>
  </body>
</html>

我将第一个脚本标签放在我的application.html.erb文件中,如下所示:

<%= javascript_include_tag "https://maps.googleapis.com/maps/api/js?key=AIzaSyAK04aYSxZArPElFFZfo3o2p-CbviPzfhc&sensor=false" %>

我有一个场地模型和一个场地控制器。我希望地图出现在场地表演动作中。所以我把第二个脚本放在里面venue.js。我的show.html.erb样子是这样的:

<div class="center">
  <h1><%= @venue.name %></h1>
  <address><%= @address %></address>
  <div id="map-canvas"/>
</div>

但是当我加载这个页面时没有地图出现。

4

1 回答 1

0

一个非常简单的方法是简单地将地图嵌入到 iframe 中。使用 .haml 进行标记,

%iframe.google-location{ frameborder: '0', scrolling: 'no', src: 'https://www.google.com/maps/embed/v1/place?q=place_id:{google_generated_placeId}' }

'google-location' 类(或任何你想命名的)只需要具有 iframe 的大小。

(确保有一个有效的 api 密钥)

于 2019-06-21T20:35:10.320 回答