这是错误:
Processing by LandingPageController#index as HTML
Rendered landing_page/index.html.erb within layouts/application (2.1ms)
Completed 500 Internal Server Error in 49ms
ActionView::Template::Error (landing_page.css isn't precompiled):
12: <![endif]-->
13:
14: <%= stylesheet_link_tag "application", :media => "all" %>
15: <%= stylesheet_link_tag params[:controller] %>
16:
17: </head>
18: <body>
app/views/layouts/application.html.erb:15:in `_app_views_layouts_application_html_erb__3002306950342527375_29178380'
我可以看到它正在寻找landing_page.css文件,因为第15行。我不明白是什么是为生产预编译此资产的最佳方法。我试过修改/config/application.rb:
config.assets.precompile += ['landing_page.css']
这对我来说似乎不对。我必须为每一个烦人的样式表做这件事。
我在application.css清单中添加了代码:
*= require landing_page
这似乎不起作用。我这样做时遇到第一个错误,不要修改应用程序配置文件。
我很难过如何包含这行
<%= stylesheet_link_tag params[:controller] %>
在您的布局中并在运行
时预先编译您的资产以进行生产bundle exec rake assets:precompile
我觉得我错过了一些简单的技巧,可以自动将自动生成的样式表和javascript文件添加到运行rake任务时要预编译的文件列表中。
答案 0 :(得分:3)
添加:
config.assets.precompile += %w( landing_page.css)
答案 1 :(得分:3)
向application.css添加require landing_page
不会导致login_page被预编译。这意味着当预编译application.css时,landing_page.css的内容将包含在输出中。
如果您要单独加载它们,即
&lt;%= stylesheet_link_tag params [:controller]%&gt;
然后,您需要将它们全部添加到要预编译的事物列表中。您可以在该列表中使用通配符,因此如果这些控制器特定的样式表都在样式表/控制器中,那么您可以这样做
config.assets.precompile + = [“controllers / *。css”]
通常人们往往不这样做。虽然为了便于开发,通常会在每个控制器的基础上拆分,然后从application.css中需要所有这些。然后,Application.css是您在
上调用stylesheet_link_tag
的唯一样式表
答案 2 :(得分:0)
这对我来说是新闻,所以我将分享:在Rails 4中,只有application.js | css清单文件文件由Rails自动编译。如果您使用的是
javascript_include_tag controller_name
# ex javascript_include_tag 'guitars'
您显然需要将自定义清单('吉他')添加到config.assets.precompile,如上所述。我{相信}这是对Rails 3.2的改变。