我正在使用 Ruby on Rails 4 开发一个站点,并且遇到了一些 CSS 文件的路径问题。
我的applicaiton.sass
文件中未包含以下资产:
- 移动.scss
- Mozilla.scss
- msie.scss
- 歌剧.scss
- webkit.scss
我已将它们包含在我application.rb
的预编译中,使用以下内容:
config.assets.precompile += [
'mobile.css',
'mozilla.css',
'msie.css',
'opera.css',
'webkit.css'
]
在我的生产服务器上,我运行了以下命令(注意:该touch
命令是为了确保应用程序重新启动并清除缓存,因为我使用 Phusion Passenger 和 Nginx 作为我的服务器):
rake assets:precompile RAILS_ENV=production
touch tmp/restart.txt
运行上述命令后,我注意到资产已预编译并驻留在我的public/assets/
目录中。它们也正确地列在目录中的manifest.json
文件中public/assets/
。
当我在浏览器中加载站点并查看源代码时,我注意到浏览器特定的 CSS 文件没有使用正确的资产路径。表明:
<link href="/assets/application-ec1031f251a585c79d4404ef2899f6d1.css" media="screen" rel="stylesheet" />
<link href="/stylesheets/webkit.css" media="screen" rel="stylesheet" />
虽然我希望看到:
<link href="/assets/application-ec1031f251a585c79d4404ef2899f6d1.css" media="screen" rel="stylesheet" />
<link href="/assets/webkit-70899fec75bb8eae24edae491a94f73a.css" media="screen" rel="stylesheet" />
我的视图看起来使用以下代码:
<% if @mobile %>
<%= stylesheet_link_tag :mobile %>
<% else %>
<%= stylesheet_link_tag :application %>
<%= stylesheet_link_tag :msie if @browser == 'Internet Explorer' %>
<%= stylesheet_link_tag :opera if @browser == 'Opera' %>
<%= stylesheet_link_tag :mozilla if @browser == 'Mozilla' %>
<%= stylesheet_link_tag :webkit if @browser == 'Webkit' %>
<% end %>
我的问题是webkit.css
路径不应该正确输出还是我遗漏了什么?任何帮助将不胜感激。