【发布时间】:2014-09-08 19:17:13
【问题描述】:
我尝试创建一个 Sprocket 指令来考虑我的配置文件中的更改:
在initializers/sprockets.rb
class Sprockets::DirectiveProcessor
def process_depend_on_config_directive(file)
path = File.expand_path(file, "#{Rails.root}/config/locales")
context.depend_on(path)
end
end
在application.js
//= depend_on_config en.yml
//= depend_on_config fr.yml
刷新相关 js 文件上的页面给了我不同的答案,我无法修复此行为:
15:02:03 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:03] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23560 0.0105 15:02:05 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:05] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23564 0.0079 15:02:06 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:06] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 304 - 0.0061 15:02:06 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:06]“得到 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23560 0.0091 15:02:07 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:07] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23564 0.0076 15:02:07 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:07] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 304 - 0.0093 15:02:08 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:08]“得到 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23560 0.0080 15:02:08 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:08] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 200 23564 0.0091 15:02:09 web.1 | 127.0.0.1 - - [2014 年 7 月 17 日 15:02:09] “获取 /angular_js/services/better_translate_service-04bd3e149eb227767d3910de31fb2489.js?body=1 HTTP/1.1" 304 - 0.0059
编辑:一些说明:
- 我想指出的是,资产文件的哈希是相同的,内容是不同的。
- 当我说刷新页面时,我的意思是我在不同的选项卡中打开资产文件,当我刷新页面时,内容会发生变化。
Edit2:添加更多信息:
更好地翻译服务文件(.erb):
<% environment.context_class.instance_eval { include ApplicationHelper } %>
<%# encoding: utf-8 %>
app.factory('Pg', ['SETTINGS', function(SETTINGS) {
var polyglot = {};
polyglot.translations = {
en: new Polyglot({ phrases: <%= I18n.with_locale(:en) { phrases_for_polyglot.to_json } %>, locale: "en" }),
fr: new Polyglot({ phrases: <%= I18n.with_locale(:fr) { phrases_for_polyglot.to_json } %>, locale: "fr" })
};
polyglot.current = 'en';
polyglot.t = _.memoize(function(key, opts) {
return polyglot.translations[polyglot.current].t(key, opts);
}, function(key, opts){
if(opts===undefined){ return polyglot.current + ''+ key; }
return polyglot.current + '' + key + polyglot.serialize(opts);
});
polyglot.serialize = function(obj) {
var str = [];
for(var p in obj){
if(obj.hasOwnProperty(p)) {
str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
}
}
return str.join("&");
};
//fde
polyglot.selectLanguage = function(lang){
polyglot.current = lang;
};
return polyglot;
}]);
开发内容.rb:
# Settings specified here will take precedence over those in config/application.rb.
# In the development environment your application's code is reloaded on
# every request. This slows down response time but is perfect for development
# since you don't have to restart the web server when you make code changes.
config.cache_classes = false
# Do not eager load code on boot.
config.eager_load = false
# Show full error reports and disable caching.
config.consider_all_requests_local = true
config.action_controller.perform_caching = false
# Don't care if the mailer can't send.
config.action_mailer.raise_delivery_errors = false
# Print deprecation notices to the Rails logger.
config.active_support.deprecation = :log
# Raise an error on page load if there are pending migrations
# config.active_record.migration_error = :page_load
# Debug mode disables concatenation and preprocessing of assets.
# This option may cause significant delays in view rendering with a large
# number of complex assets.
config.assets.debug = true
config.assets.digest = true
config.assets.configure do |env|
env.cache = ActiveSupport::Cache.lookup_store(:null_store)
end
我正在使用 Rails 4.1.1。有什么建议?我可以根据需要提供更多信息。
尝试答案后更新:我按照以下答案进行了以下更改:
application.js => application.js.erb
<%= depend_on 'en.yml' %>
<%= depend_on 'fr.yml' %>
<% I18n.backend.send(:init_translations) unless I18n.backend.initialized? %>
console.log(<%= I18n.backend.send(:translations).to_json %>);
//= require angular-rails-templates
//= require honeybadger.min
//= require_tree ./dependencies
//= require lodash.min
//= require polyglot.min
//= require lunr.min
//= require angulartics.min
//= require angulartics-ga.min
//= require ./angular_js/fancyinput_library/ac-fancy-input
//= require angular-main
//= require_tree ./angular_js
//= require_tree ../templates
将以下内容添加到 application.rb
config.assets.paths
新发展.rb
# Settings specified here will take precedence over those in config/application.rb.
# In the development environment your application's code is reloaded on
# every request. This slows down response time but is perfect for development
# since you don't have to restart the web server when you make code changes.
config.cache_classes = false
# Do not eager load code on boot.
config.eager_load = false
# Show full error reports and disable caching.
config.consider_all_requests_local = true
config.action_controller.perform_caching = false
# Don't care if the mailer can't send.
config.action_mailer.raise_delivery_errors = false
# Print deprecation notices to the Rails logger.
config.active_support.deprecation = :log
# Raise an error on page load if there are pending migrations
# config.active_record.migration_error = :page_load
# Debug mode disables concatenation and preprocessing of assets.
# This option may cause significant delays in view rendering with a large
# number of complex assets.
config.assets.compile = true
config.serve_static_assets = true
config.assets.debug = false
config.assets.digest = true
# config.assets.configure do |env|
# env.cache = ActiveSupport::Cache.lookup_store(:null_store)
# end
# config.middleware.use Rack::Prerender
config.root_url = 'lvh.me:5000'
config.api_host = 'http://lvh.me:3000'
结果:js 错误,应用未加载。
JS 错误:
(anonymous function) MINERR_ASSET:22
(anonymous function) angular.js:3650
q angular.js:303
e angular.js:3616
$b angular.js:3556
Zb.c angular.js:1299
Zb angular.js:1314
Tc angular.js:1263
(anonymous function) angular.js:20555
a angular.js:2342
(anonymous function) angular.js:2613
q angular.js:310
Zc.c angular.js:2612
浏览器中的js文件:
console.log( ... );
//= require angular-rails-templates
//= require honeybadger.min
//= require_tree ./dependencies
//= require lodash.min
//= require polyglot.min
//= require lunr.min
//= require angulartics.min
//= require angulartics-ga.min
//= require ./angular_js/fancyinput_library/ac-fancy-input
//= require angular-main
//= require_tree ./angular_js
//= require_tree ../templates
;
更新 2:我几乎明白了。我注意到我没有在正确的文件中包含 depend_on 方法。我将它们移至相关的 .js.erb 并开始工作。我唯一剩下的问题是我必须刷新页面两次。我认为如果 application.js 无论如何都保持不变会更好。 :)
【问题讨论】:
标签: ruby-on-rails caching asset-pipeline sprockets