提交 87323487 编写于 作者: G Godfrey Chan

Merge pull request #13442 from aditya-kapoor/update-docs

Updated documentation for Attribute Methods [ci skip]
......@@ -14,11 +14,11 @@ module ActiveModel
class MissingAttributeError < NoMethodError
end
# == Active Model Attribute Methods
# == Active \Model \Attribute \Methods
#
# <tt>ActiveModel::AttributeMethods</tt> provides a way to add prefixes and
# suffixes to your methods as well as handling the creation of
# <tt>ActiveRecord::Base</tt>-like class methods such as +table_name+.
# Provides a way to add prefixes and suffixes to your methods as
# well as handling the creation of <tt>ActiveRecord::Base</tt>-like
# class methods such as +table_name+.
#
# The requirements to implement <tt>ActiveModel::AttributeMethods</tt> are to:
#
......@@ -27,7 +27,9 @@ class MissingAttributeError < NoMethodError
# or +attribute_method_prefix+.
# * Call +define_attribute_methods+ after the other methods are called.
# * Define the various generic +_attribute+ methods that you have declared.
# * Define an +attributes+ method, see below.
# * Define an +attributes+ method which returns a hash with each
# attribute name in your model as hash key and the attribute value as hash value.
# Hash keys must be strings.
#
# A minimal implementation could be:
#
......@@ -42,7 +44,7 @@ class MissingAttributeError < NoMethodError
# attr_accessor :name
#
# def attributes
# {'name' => @name}
# { 'name' => @name }
# end
#
# private
......@@ -59,13 +61,6 @@ class MissingAttributeError < NoMethodError
# send("#{attr}=", 'Default Name')
# end
# end
#
# Note that whenever you include <tt>ActiveModel::AttributeMethods</tt> in
# your class, it requires you to implement an +attributes+ method which
# returns a hash with each attribute name in your model as hash key and the
# attribute value as hash value.
#
# Hash keys must be strings.
module AttributeMethods
extend ActiveSupport::Concern
......@@ -173,14 +168,14 @@ def attribute_method_suffix(*suffixes)
# private
#
# def reset_attribute_to_default!(attr)
# ...
# send("#{attr}=", 'Default Name')
# end
# end
#
# person = Person.new
# person.name # => 'Gem'
# person.reset_name_to_default!
# person.name # => 'Gemma'
# person.name # => 'Default Name'
def attribute_method_affix(*affixes)
self.attribute_method_matchers += affixes.map! { |affix| AttributeMethodMatcher.new prefix: affix[:prefix], suffix: affix[:suffix] }
undefine_attribute_methods
......@@ -250,7 +245,7 @@ def attribute_alias(name)
# private
#
# def clear_attribute(attr)
# ...
# send("#{attr}", nil)
# end
# end
def define_attribute_methods(*attr_names)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册