我用一个简单的带有索引函数的页面控制器做了一个基本的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 = 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 \;

其他回答

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

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

默认情况下,Rails假定您已经在生产环境中预编译了您的文件,如果您想在生产环境中使用实时编译(在运行时编译您的资产),您必须将config.assets.compile设置为true。

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

当您使用预编译的资产,但有任何丢失的预编译文件时,您可以使用此选项回退到链轮。

如果config.assets.compile选项设置为false,并且有丢失的预编译文件,您将得到一个“AssetNoPrecompiledError”,指示丢失的文件的名称。

我在开发环境中也犯了完全相同的错误。最后,我所需要做的就是修改它:

config.assets.manifest = Rails.root.join("public/assets")

到我的配置/环境/开发。Rb文件,它修复了它。我在开发中与资产相关的最终配置如下:

config.assets.compress = false  
config.assets.precompile += %w[bootstrap-alerts.js] #Lots of other space separated files
config.assets.compile = false
config.assets.digest = true
config.assets.manifest = Rails.root.join("public/assets")
config.assets.debug = true

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

bundle exec rake assets:precompile

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

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

解决方案是使用如上所述

bundle exec rake assets:precompile

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

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

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