Rails资产未在生产中编译

时间:2012-07-03 06:02:41

标签: ruby-on-rails stylesheet asset-pipeline

这是错误:

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任务时要预编译的文件列表中。

3 个答案:

答案 0 :(得分:3)

在/config/environments/production.rb中

添加:

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的改变。