资产在预编译时说“未预编译”

时间:2011-10-03 21:21:05

标签: ruby-on-rails ruby-on-rails-3.1 asset-pipeline sprockets

好的,我在尝试使用资产管道时遇到此错误。我不明白是什么导致了它。

Sprockets::Helpers::RailsHelper::AssetPaths::AssetNotPrecompiledError in Photos#show

Showing .../app/views/photos/_photo_view.html.haml where line #2 raised:

jquery.autocomplete isn't precompiled

Extracted source (around line #2):

1: - content_for :scripts do
2:  = javascript_include_tag 'jquery.autocomplete'

但是,这是预先编译的。我在启动服务器之前运行了rake assets:precompile RAILS_ENV=production,在我的public/assets目录中我有文件:jquery-5550a245a55b28927b5552cac182e612.autocomplete.js以及.js.gz,并且它已准确地反映在清单中:

#manifest.yml
---
application.js: application-4277323e3f7506b71f45c71e8a3a7c8f.js
jquery.autocomplete.js: jquery-5550a245a55b28927b5552cac182e612.autocomplete.js
jquery.cycle.all.min.js: jquery-183ef696b43944deaee5778d3094dbdd.cycle.all.min.js
jquery.fancybox.js: jquery-e52e44b2b4fb349bade9beb91461a810.fancybox.js
jquery.plupload.queue.js: jquery-f2e7f6ad7d2e5ca50235ed21f8d573cc.plupload.queue.js
jquery.tools.js: jquery-c53e304240fa56767fe0f2a00cb4bceb.tools.js
plupload.full.js: plupload-5dd26ee3fff6b627c19f196e9d1429dd.full.js
application.css: application-ce5217e1714cbc4e9c3ff6c5dfc9b221.css
fancybox.css: fancybox-9ee9c36f391086e4b0629b7df4042390.css
jquery.plupload.queue.css: jquery-661fbf3f503aa32ff11c004838c0820b.plupload.queue.css
jquery.js: jquery-4d23f0cfea862f56deb04f0a8ab1fcee.js
jquery.min.js: jquery-8a50feed8d29566738ad005e19fe1c2d.min.js

我的application.js文件中没有加载有问题的javascript文件,因为我只需要在一个视图中使用它,并且不要在应用程序的任何其他地方使用它。考虑到这一点(并修复链接尝试编译sass部分)我配置了我的预编译regexp,如下所示:

#environments/production.rb
config.assets.precompile = [/^[a-zA-Z]*\..*/]

(上面的regexp预编译任何以字母字符开头的文件,并忽略以非字母字符开头的文件,如下划线)。

有没有人能够了解导致这种情况的原因以及如何解决这个问题?资产管道让我脱掉头发!

更新

刚刚发现Rails.configuration.assets.digests在生产中返回nil。也许问题存在,由于某种原因,链轮没有找到manifest.yml。

我可能错了,但看起来sprockets在查找manifest.yml时没有在config中使用assets_host。

https://github.com/rails/rails/blob/3-2-stable/actionpack/lib/sprockets/railtie.rb#L38

3 个答案:

答案 0 :(得分:16)

.js添加到

javascript_include_tag 'jquery.autocomplete.js'

似乎缺少功能。当文件名具有句点'。'时在名称中,查看摘要时不会添加.js扩展名。

我对Sprockets::Helpers::RailsHelper进行了一些调试,似乎digest_for方法获得了没有 .js 的逻辑路径。

答案 1 :(得分:4)

我一直在努力解决这个问题,虽然设置了config.assets.compile = false,因为我怀疑上面的例子是将标志设置为true

Cannot configure assets via pipeline on local production rails 3.1.3 server

我的观察归结为它是一个Sprockets 2.0.3错误,正如UberNeet建议的那样。解决方法是从资产名称中删除期间,或将其作为清单的一部分包含在内,而不是直接链接到它。

此处的错误报告位于:https://github.com/rails/rails/issues/3398

查看上面的问题,并根据我过去两天的经验计算,我怀疑在设置config.assets.compile = true时资产命名存在相关问题。此问题可能源于资产命名 - 您的清单将jquery.autocomplete库编译为:

jquery-5550a245a55b28927b5552cac182e612.autocomplete.js

但是当你使用rake assets:precompile通过rake预编译这些资产时,我相信它们实际编译为:

jquery.autocomplete-5550a245a55b28927b5552cac182e612.js

这可能是导致您提到的问题的差异。可能值得为此提出另一个github问题,虽然上面列出了变通方法,但我知道Rails 3.2将使用Sprockets 2.1.0,它可能已包含此问题的修复程序。

答案 2 :(得分:0)

例如,在application.js之前不需要它。