ruby-on-rails – 为什么Rails 5使用ApplicationRecord而不是ActiveRecord :: Base?

我们知道Rails 5将ApplicationRecord作为一个抽象类,它被继承自我们的模型(ActiveRecord).

但是基本上我认为我们使用ApplicationRecord所做的每一个技术要求,我们也可以使用ActiveRecord :: Base.例如:

module MyFeatures
  def do_something
    puts "Doing something"
  end
end

class ApplicationRecord < ActiveRecord::Base
  include MyFeatures
  self.abstract_class = true
end

所以现在每个模型都会附加到MyFeatures的行为.但是我们也可以在Rails 4中实现这一点:

ActiveRecord::Base.include(MyFeatures)

那么使用ApplicationRecord有什么好处,你认为有必要添加ApplicationRecord吗?

解决方法

虽然在基本的Rails应用程序中看起来可能相同,但是从ActiveRecord :: Base开始使用rails引擎,插件/ gem或直接方法之后,实际上有一个重要的区别.

> ActiveRecord :: Base.include(MyFeatures)将功能直接混合到ActiveRecord :: Base中,它永远存在于ActiveRecord :: Base的所有后续应用中(它不能是“未混合”),并且没有办法获取原来的ActiveRecord :: Base后面的任何代码都包含在内.如果某些混合功能更改了认的ActiveRecord行为,或者例如,两个引擎/宝石试图包含相同的方法.
>另一方面,ApplicationRecord方法使特征仅存在于继承自它的类(模型),其他类,以及直接使用ActiveRecord :: Base保持原始状态,由模块功能整合.

当使用引擎或导轨插件时,这是特别重要的,因为它允许他们将自己的模型逻辑与ApplicationRecord之间无法使用的主应用程序的模型逻辑分开.

所有这一切在this blog postthis github comment也很好描述.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...