ruby-on-rails – 在Rails初始化上加载子索引

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 在Rails初始化上加载子索引前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_301_1@我遇到了让Rails(3.1.3)在应用程序初始化时加载一些ActiveRecord子类的问题.这是我的目录结构:
- models
  - class1.rb # Class1 < ActiveRecord::Base
  - class1s
    - subclass1.rb # Subclass1 < Class1
    - subclass2.rb # Subclass2 < Class1

我试图使用Class1.subclasses,但它一直返回[].将#{config.root} / app / models / class1s添加到config.autoload_paths没有帮助,因为这些子句是延迟加载的,并且在我调用子类之前没有引用子类,因此它们已被加载.添加config.eager_load_paths的路径似乎也不起作用,其行为基于config.cache_classes设置,这在开发和生产中通常是不同的.

我希望能够启动rails控制台并查看:

> Class1.subclasses
 => [Subclass1,Subclass2]

现在这是我看到的行为:

> Class1.subclasses
 => []
> Subclass1
 => Subclass1
> Class1.subclasses
 => [Subclass1]
> Subclass2
 => Subclass2
> Class1.subclasses
 => [Subclass1,Subclass2]

现在,我被简化为将它放在我的Class1定义的底部,以便在访问Class1类时加载所有子类:

ruby_files_pattern = File.join(Rails.application.config.root,"app","models","class1s","**","*.rb")
Dir.glob(ruby_files_pattern).each do |file|
  ActiveSupport::Dependencies.require_or_load(file)
end

它完成了工作,但我觉得这样做很脏.任何想法将不胜感激.

解决方法

最简单的方法是使用(> = 3.0)加载所有类:
Rails.application.eager_load!

它将从您的应用程序,引擎,插件加载所有类.与配置中延迟加载的结果相同.但是在这种方法中你不需要这样做只使用这种方法.

猜你在找的Ruby相关文章