我用一个简单的带有索引函数的页面控制器做了一个基本的rails应用程序,当我加载页面时,我得到:

ActionView::Template::Error (application.css isn't precompiled):
    2: <html>
    3: <head>
    4:   <title>Demo</title>
    5:   <%= stylesheet_link_tag    "application" %>
    6:   <%= javascript_include_tag "application" %>
    7:   <%= csrf_meta_tags %>
    8: </head>
  app/views/layouts/application.html.erb:5:in `_app_views_layouts_application_html_erb__43625033_88530400'

Gemfile

source 'http://rubygems.org'

gem 'rails', '3.1.0'

# Bundle edge Rails instead:
# gem 'rails',     :git => 'git://github.com/rails/rails.git'

gem 'sqlite3'

gem 'execjs'
gem 'therubyracer'

# Gems used only for assets and not required
# in production environments by default.
group :assets do
  gem 'sass-rails', "  ~> 3.1.0"
  gem 'coffee-rails', "~> 3.1.0"
  gem 'uglifier'
end

gem 'jquery-rails'

# Use unicorn as the web server
# gem 'unicorn'

# Deploy with Capistrano
# gem 'capistrano'

# To use debugger
# gem 'ruby-debug19', :require => 'ruby-debug'

group :test do
  # Pretty printed test output
  gem 'turn', :require => false
end

当前回答

如果在生产环境中将config.assets.compile设置为false,您将在生产环境中获得更好的性能。Rb和预编译你的资产。你可以用这个rake任务预编译:

bundle exec rake assets:precompile

如果您正在使用Capistrano,版本2.8.0有一个在部署时处理这个问题的方法。要了解更多信息,请参阅资产管道指南的“生产中”部分: http://guides.rubyonrails.org/asset_pipeline.html

其他回答

如果在生产环境中将config.assets.compile设置为false,您将在生产环境中获得更好的性能。Rb和预编译你的资产。你可以用这个rake任务预编译:

bundle exec rake assets:precompile

如果您正在使用Capistrano,版本2.8.0有一个在部署时处理这个问题的方法。要了解更多信息,请参阅资产管道指南的“生产中”部分: http://guides.rubyonrails.org/asset_pipeline.html

在heroku服务器(只读文件系统), 如果你想运行时编译css(不建议,但你可以这样做),确保你已经做了如下设置-

# inside config/application.rb
config.assets.enabled = true
config.assets.prefix = Rails.root.join('tmp/assets').to_s

# If you are using sass then keep gem outside of asset group
 gem 'sass-rails',   '3.1.4'

# inside config/environments/production.rb
config.assets.compile = true

好吧,我也遇到过同样的问题。我不想使用"config.assets.compile = true" -我必须将我所有的.css文件添加到config/environments/production.rb的列表中:

config.assets.precompile += %w( carts.css )

然后我必须创建(然后删除)tmp/restart.txt

我一直使用stylesheet_link_tag helper,所以我找到了我需要添加的所有额外的css文件:

find . \( -type f -o -type l \) -exec grep stylesheet_link_tag {} /dev/null \;

对于所有阅读本文但对application.css没有问题的人,而是使用他们的自定义CSS类,例如admin.css, base.css等。

解决方案是使用如上所述

bundle exec rake assets:precompile

样式表中的引用只是引用application.css

<%= stylesheet_link_tag    "application", :media => "all" %>

因为assets pipeline会预编译application.css中的所有样式表。这在开发中也会发生,所以在使用资产管道时使用任何其他引用都是错误的。

一个快速修复capistrano用户是把这一行到Capfile

# Uncomment if you are using Rails' asset pipeline
load 'deploy/assets'