class Model
include ActiveModel::Validations
include ActiveModel::Conversion
extend ActiveModel::Naming
attr_accessor :whatever
validates :whatever, :presence => true
def initialize(attributes = {})
attributes.each do |name, value|
send("#{name}=", value)
end
end
def persisted?
false
end
end
7条答案
按热度按时间z9zf31ra1#
attr_accessor将创建你的属性,你将使用initialize()创建对象并设置属性。
持久化的方法将告诉没有与数据库的链接。你可以找到这样的例子:http://railscasts.com/episodes/219-active-model?language=en&view=asciicast
这将解释你的逻辑。
holgip5t2#
2013年的答案是好的,但是自Rails 4以来,
ActiveRecord
的所有数据库独立特性都被提取到ActiveModel
中。此外,还有一个很棒的官方指南。您可以根据需要包含任意多个模块,也可以包含任意少个模块。
举个例子,你只需要
include ActiveModel::Model
,你可以放弃这样一个initialize
方法:只需用途:
6ojccjat3#
最简单的答案就是不要从ActiveRecord::Base中继承子类。然后你就可以写你的目标代码了。
p1tboqfb4#
在Rails 6中为我工作的是:
pn9klfpd5#
如果您需要一个没有关联表的模型的原因是创建一个抽象类,那么从- *
ActiveRecord
* 继承的真实的模型支持:uubf1zoe6#
如果你想有一个选择列表(不会演变),你可以在
ApplicationHelper
中定义一个返回列表的方法,例如:kyvafyod7#
我在Rails 7中,但我认为这在Rails 6中也有效:
与
attr_accessor
替代方案相比,我更喜欢它,因为它允许我将属性解析为数据库。