質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.25%

更新するとGoogleMapが表示されなくなる

受付中

回答 0

投稿

  • 評価
  • クリップ 0
  • VIEW 557

Ryota000666

score 5

質問失礼いたします。
現在rails でポートフォリオ作成中です。

【実装したいこと】

Google Mapを記事詳細ページで表示したい

【詳細】

Google Mapを記事詳細ページで表示することはできたのですが、そのページを更新するとconsoleでエラーが出てGoogle Mapが表示されなくなります。
エラーの内容は

Uncaught ReferenceError: google is not defined
    at eval (eval at <anonymous> (infobox_packed.js:1), <anonymous>:1:1066)
    at infobox_packed.js:1
eval @ VM50170:1
(anonymous) @ infobox_packed.js:1


44:1 Uncaught (in promise) pd {message: "Map: Expected mapDiv of type Element but was passed null.", name: "InvalidValueError", stack: "Error↵    at new pd (https://maps.googleapis.com/m…4t136yIMuX6XJROiWOfKHmCBM&callback=initMap:141:75"}


と言うものです
その他にも

You have included the Google Maps JavaScript API multiple times on this page. This may cause unexpected errors.


が出ることがあり
このページではAPIを一回しか読み込んでいないので、なぜこのエラーが出るのかも分かりません。
おそらく、更新によりAPIが二度読み込まれ、このようなことになっているのだと推測しましたが、改善方法が分かりません。
もし分かる方いましたら、ご回答いただけると幸いです。よろしくお願いいたします。

エラーがでているページのhtml

<div class="post-wrap">
  <div class="post-image">
    <% if @cafepost.image.url.nil? %>
    <%= image_tag 'noimage.png' %>
    <% else %>
    <%= image_tag @cafepost.image.url %>
    <% end %>
  </div>
  <div class="post-detail">
    <div class="post-detail-left">
      <div class="post-user-detail">
        <%= image_tag @cafepost.user.image.thumb23.url %>
        <p><%= link_to @cafepost.user.name, @cafepost.user %></p>
      </div>
      <p class="post-time">
        <%= @cafepost.updated_at.strftime("%Y/%m/%d") %>
      </p>
      <p class="post-postcode"><%= @cafepost.postcode %></p>
      <p class="post-address">
        <%= @cafepost.address_all %>
      </p>
    </div>
    <div class="post-detail-right">
      <p class="post-content"><%= @cafepost.content %></p>
      <% if @cafepost.wifi %>
      <p>wifiあります</p>
      <% end %>
      <% if @cafepost.power %>
      <p>コンセントあります</p>
      <% end %>
    </div>
  </div>

  <h2>コメント一覧</h2>
  <div>コメント<%= @comments.count %></div>
  <% @comments.each do |c| %>
    <div>
      <%= link_to c.user.name, user_path(c.user) %>
      <%= c.content %>
      <hr>
    </div>
  <% end %>

  <%= form_for [@cafepost, @comment] do |f| %>
    <%= f.text_field :content %>
    <%= f.hidden_field :cafepost_id, value: @cafepost.id %>
    <br>
    <%= f.submit 'コメントする' %>
  <% end %>

</div>


<script type="text/javascript">
  function initMap() {
    var test = {lat: <%= @cafepost.latitude %>, lng: <%= @cafepost.longitude %>};
    var map = new google.maps.Map(document.getElementById('map'), {
              zoom: 15, 
              center: test
              });
    var transitLayer = new google.maps.TransitLayer();
    transitLayer.setMap(map);

    var contentHTML = '<p><%= @cafepost.title%></p><p>場所:<%= @cafepost.address_all %></p>';
    var infowindow = new google.maps.InfoWindow({
      content: contentHTML
    });

    var marker = new google.maps.Marker({
                  position:test,
                  map: map,
                  title: contentHTML
                 });

     marker.addListener('click', function() {
       infowindow.open(map, marker);
     });
  }
</script>

    <script src="https://maps.googleapis.com/maps/api/js?v=3.exp&key=MyAPIKey=initMap"></script>




<style type="text/css">
  #map { height: 200px;
         width: 70%;}
</style>


  <div id="map"></div>

APIの表示は伏せています。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.25%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる