Rails 4 编译供应商资产但不是 application.js 和 application.css

Rails 4 compiling vendor assets but not application.js and application.css

我有一个旧的 Rails 3 应用程序,我正在升级到 Rails 4。Sprockets 似乎正在添加后缀并使用我在 /vendor 中的 Javascript,但是我的 assets/javascripts/application.js、assets/stylesheets/application.css 和 assets/images/... 无法正常工作。在 HTML 中,我可以看到它们有后缀,但它们在尝试加载时出错。

例如,这有效: 0.0.0.0:8080/assets/jquery-1.8.3.min-95a3734fc817813c8ba0cd3438033917a3863503b2ca20e8b30a7f61b031576f.js

但这不是: 0.0.0.0:8080/assets/application-7437324e57ae6cb54f03eaa608a99381fca68ad72ed2009f8fccd49f41f34bac.css

但是,这有效: 0.0.0.0:8080/assets/application.css

图像也不起作用。当我执行 image_tag 时,它给出 Sprockets::Rails::Helper::AssetNotPrecompiled 错误。

Rails4 在本地开发模式下是否应该添加后缀?

如果是,Rails 4 和 Sprockets 有什么问题 - 我需要以某种方式更改我的配置吗?

这些“后缀”是哈希值,意味着文件内容是唯一的。大多数情况下,这作为一种缓存技术在生产中很有用。自从我将应用程序从 3 移动到 4 已经很长时间了。现代 rails 应用程序正在使用 webpack 来处理很多这样的事情,但资产管道现在仍然有效。

我记得哈希不是在开发模式下生成的。如果您还没有阅读有关预编译资产的文档,您应该阅读。