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

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

ただいまの
回答率

90.01%

Rails5.2.1で任意のJavaScriptを読み込む方法が分かりません。

解決済

回答 1

投稿

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

kenkenbbb

score 14

Rails5.2.1でWebアプリケーションの学習を行なっています。現在、google maps apiを使って、マップを表示させるだけの簡単なプログラムを作っています。そこで、マップを描画させる命令をJavaScript(以下、JS)で記述したのですが、ページを表示させた時に、別ファイル(google_map.js)に記述したJSが読み込まれないため困っています。

また、環境についてはAWSのCloud9を使用しています。

 ソースコード

index.html.erb

<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="utf-8">
  <title>Google Map</title>
  <style>
    #google_map {
      width: 700px;
      height: 350px;
    }
  </style>
</head>
<body>
  <div id="google_map"></div>
  <script src="https://maps.googleapis.com/maps/api/js?language=ja&region=JP&key=****"></script>

</body>
</html>


google_map.js

(function() {
  'use strict';
  console.log("hoge.js")//jsが読み込まれているか確認するため

  var target = document.getElementById('google_map');
  var map;
  var tokyo = {lat: 35.681167, lng: 139.767052};

   window.addEventListener('load', function() {  
       map = new google.maps.Map(target, {
       center: tokyo,
       zoom: 15
       });
   });
})();

 試したこと

①index.html.erbに<script>タグを埋め込んで、google_map.jsの中身を直書きした場合には、マップが問題なく表示されました。

②application.jsには以下の記述をしています。

//= require rails-ujs
//= require activestorage
//= require jquery
//= require jquery_ujs
//= require turbolinks
//= require_tree .

console.log("application.js")


ページを読み込んだ際にconsole.logの中身は表示されました。

③gemfileには以下の記述を追加して、bundle installとrailsサーバーの再起動をしています。

gem 'jquery-rails'


④google_map/jsの保存場所は、/google_map/app/assets/javascripts/です。

application.jsに "//= require_tree ."を記述したので、assets以下のファイルに保存したJSファイルが自動的に読み込まれると思ったのですが、Railsの「アセットパイプライン」の仕組みが理解しきれず悩んでいます。JSを読み込ませる方法は多々あるかと思いますが、Railsの仕組みを理解するため、任意のJSを読み込む方法を勉強しています。初学者の質問で読みづらい点が多々あるかと思いますが、解決策等ご教授頂けると幸いです。よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • ryochin

    2018/09/23 12:11

    お手元の development 環境において、表示される html の中に <script src="/assets/google_map.self-85c50dffdc3b57a924a75001c17cb4401f80994bf675348ffe996b0582b416df.js?body=1"></script> のような script タグは存在しますか?

    キャンセル

  • kenkenbbb

    2018/09/25 13:12

    連絡が遅くなり申し訳ありません。手元の環境ですと、/environment/google_map/app/views/layouts/application.html.erbにscriptタグを埋め込んでいます。application.jsは読み込まれているみたいのですが、google_map.jsは読み込まれないという状況です、、、。

    キャンセル

回答 1

checkベストアンサー

0

一般的には、app/views/layouts/application.html.erb に

    <%= javascript_include_tag 'application' %>

を記述すると自動的に読み込まれます。

ですが、上記の index.html.erb の書き方からすると、layout 機能を使用されていないように見受けられますので、その場合は index.html.erb の <head></head> 内に javascript_include_tag を直接記述することになります(が、素直に layout を使用しヘッダ部分を共通化するのをお勧めします)。

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <%= javascript_include_tag 'application' %>
    <title>...</title>
  </head>
  ...

参考: https://ruby-rails.hatenadiary.com/entry/20140810/1407603600

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/09/27 16:11

    回答ありがとうございます!自分のcloud9環境で、頂いたアドバイスをもとに修正した結果、無事にJSファイルを読み込むことができました。

    application.jsに「//= require_tree .」という記述をしていたのですが、上手く動作しなかったため、「// require_tree .」とし、自動読み込みを無効にした上で、「プリコンパイルの追加」と「 index.html.erb の <head></head> 内に javascript_include_tag を直接記述」をしたことで、無事に動作することが確認できました。

    Railsの動作を改めて勉強・理解することができました!ありがとうございます!

    キャンセル

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

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