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

当前回答

您可能在使用的css中有语法错误。

执行此命令

$ bundle exec rake assets:precompile RAILS_ENV=development --trace

它会给出一个异常,修正后就完成了。

谢谢

其他回答

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

解决方案是使用如上所述

bundle exec rake assets:precompile

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

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

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

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

bundle exec rake assets:precompile

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

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

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

下面是快速解决方法:

如果你正在使用capistrano,那么就这样把它添加到你的部署中。

after 'deploy:update_code' do
  run "cd #{release_path}; RAILS_ENV=production rake assets:precompile"
end

帽部署

在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