前提・実現したいこと
ヘッダーにまとめた画像を、どのページに遷移しても表示できるようにしたい。
ここに質問の内容を詳しく書いてください。
RubyでWebアプリケーションを作成しています。
部分テンプレートを用いて_header.html.erbを作成してところ、トップページを離れると画像が表示されません。
ブラウザ上のエラーは出ていません。
発生している問題・エラーメッセージ
ActionController::RoutingError (No route matches [GET] "/css/style.css"): 同様のエラーがターミナル上で画像数分確認されます。
該当のソースコード
_header.html.erb <!doctype html> <html lang="ja"> <head> <meta charset="UTF-8"> <div class="title"> <% if user_signed_in?%> <h2><%= link_to current_user.nickname %></h2> <%= link_to "ログアウト", destroy_user_session_path, method: :delete %> <% else %> <h2></h2> <%= link_to "新規登録", new_user_registration_path %> <%= link_to "ログイン", new_user_session_path %> <% end %> </div> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>今日のトレーニング</title> <link rel="stylesheet" media="all" href="css/ress.min.css" /> <link rel="stylesheet" media="all" href="css/style.css" /> <script src="js/jquery-2.1.4.min.js"></script> <script src="js/style.js"></script> <!-- Favicon --> <link rel="icon" type="assets/png" href="assets/favicon.png"> </head> <body> <header> <div class="container"> <div class="row"> <div class="col span-12"> <div class="head"> <h1><%= link_to "training diary", root_path %></h1> <div class="snsbox"> <img src="assets/in-icon.png" alt="Instagram"> <img src="assets/fb-icon.png" alt="Facebook"></div> </div> </div></div> <div class="row"> <div class="col span-12"> <nav> <div id="open"></div> <div id="close"></div> <div id="navi"> <ul> <li><%= link_to "ホーム", root_path %></li> <li><%= link_to "今日のトレーニング", new_main_path %></li> </ul> </div> </nav> </div> </div> </div> 各viewでは <%= render "shared/header" %> で部分テンプレートを呼び出しています。
試したこと
例
<img src="assets/in-icon.png" alt="Instagram">
ここのaseetsをimageやimgに記述を変更。
すると、トップページでも表示されなくなりました。
altに記述している内容が反映されています。
補足情報(FW/ツールのバージョンなど)
Macbook Air
OS Big Sur ver.11.4
よろしくお願いします。
Railsのバージョンは何でしょうか? style.css は具体的にはどのdirectory (folder)に置いていますか?
大昔のRails は知りませんが、最近のRailsであれば、スタイルファイルは直書きするのではなく `stylesheet_link_tag` で指定するのが標準だと思います(自サーバーではなくてremoteのスタイルファイルを使うならば別ですが)。
あなたの回答
tips
プレビュー