技術

【Rails】productionモードでCSSの画像が表示されない

投稿日:

どうも中田です。

css内で画像を設定して、productionモードで動かすと画像が出ない!!(タイトルとそのままのこと言っちゃった)
ってことがあったので書いておきます。

rails4にてproductionモードで動作させる場合、事前にcss、js、画像ファイルなどのアセットをプリコンパイルする。
その際、ファイル名の後ろにダイジェストが付与されるのだが、css内部で画像を指定する場合、ダイジェストまで意識しないといけない。

プリコンパイル前のファイル名

login.png

プリコンパイル後のファイル名

login-df4b86a870a56daf4e6d646db6ce8e55.png”

#main {
  background-image: url("login.png");
}

cssでこのように定義するともちろん画像は表示されない。
では、どうするか。

手順は3つ
1. css -> scss 拡張子にする
2. url -> image-url にする
3. プリコンパイル実施 (bundle exec rake assets:precompile RAILS_ENV=production)

#main {
  background-image: image-url("login.png");
}

これでOK。
プリコンパイルした際、ちゃんと画像ファイルに付与されるダイジェストを入れた状態でCSSが生成される。

感謝サイト:
http://kgmx.hatenablog.com/entry/2014/06/26/085304

-技術
-

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

関連記事

プログラミンを触ってみた

2020年から小学校でのプログラミング教育が必修になる(かも?)ということで、 …

[Xcode] iOSソフトウェアアップデート後に、Could not locate device support files.

こんにちは。たなかです。 Xcodeで開発中に以下のエラーにぶつかりました。 エ …

no image

ng-ifのelse句でコンポーネントのプロパティと名前重複

こんにちは、コーテッグのこやまです。 Angularを触っていたら、コンポーネン …

no image

【nginx/unicorn】(13: Permission denied) while connecting to upstream

どうも中田です。 AWS上でAPIサーバを構築してて、 * Webサーバ:ngi …

rails_logo

[Rails] image_tagを使わずにassets内の画像を指定する方法

こんにちは。さとうです。 今回はimage_tagを使わずにassets内の画像 …