config.assets.precompile无效

我有一个bookmarklet,需要单独的js和css文件 – 即我不希望它们像往常一样编译成一个文件。

这些是我想要与通常的js和css文件分开的文件:

assets/javascripts/bookmarklet/tagger.js assets/javascripts/bookmarklet/js/bookmarklet.js assets/stylesheets/bookmarklet/bookmarklet-frame.css 

application.jsapplication.css我改变了//= require_three .//= require_directory .

我补充说:

 config.assets.precompile += [ 'bookmarklet/js/bookmarklet.js', 'bookmarklet/tagger.js', 'bookmarklet/bookmarklet-frame.css' ] 

到我的production.rbstaging.rb

生成了application.jsapplication.css ,但是我的三个单独的文件不是。 知道为什么这不起作用吗?

确保你有require_tree而不是require_directory,require_tree递归添加但require_directory没有。 参考资产管道

application.js

 //= require jquery //= require jquery_ujs //= require_tree . 

application.css

 /* ... *= require_self *= require_tree . */ 

application.html.erb应该有这些行

 <%= javascript_include_tag "application" %> <%= stylesheet_link_tag "application" %> 

现在,当您使用命令RAILS_ENV=production bundle exec rake assets:precompile生产中的RAILS_ENV=production bundle exec rake assets:precompile您将拥有(所有js文件编译为一个,css编译为一个)

application.html.erb

   

这是不必要的,因为默认情况下application.js,application.css是预编译的。

 config.assets.precompile += [ 'bookmarklet/js/bookmarklet.js', 'bookmarklet/tagger.js', 'bookmarklet/bookmarklet-frame.css' ] 

有时您可以使用admin.js作为布局admin.html.erb然后您需要在production.rb中添加这样的行

不得不搬家

 config.assets.precompile += [ 'bookmarklet/js/bookmarklet.js', 'bookmarklet/tagger.js', 'bookmarklet/bookmarklet-frame.css' ] 

application.rb

考虑移动到application.rb的另一个解决方案可能没有必要。 相反,在config / application.rb中将’production’添加到:assets。 默认情况下,“生产”不包含在列表中。

 if defined?(Bundler) # If you precompile assets before deploying to production, use this line Bundler.require(*Rails.groups(:assets => %w(development test production))) # If you want your assets lazily compiled in production, use this line # Bundler.require(:default, :assets, Rails.env) end