Module: ActiveModel::Attributes
- Extended by:
- ActiveSupport::Concern
- Includes:
- AttributeMethods
- Defined in:
- lib/active_model/attributes.rb
Overview
:nodoc:
Defined Under Namespace
Modules: ClassMethods
Constant Summary
Constants included from AttributeMethods
ActiveModel::AttributeMethods::CALL_COMPILABLE_REGEXP, ActiveModel::AttributeMethods::NAME_COMPILABLE_REGEXP
Instance Method Summary collapse
-
#attribute_names ⇒ Object
Returns an array of attribute names as strings.
-
#attributes ⇒ Object
Returns a hash of all the attributes with their names as keys and the values of the attributes as values.
- #initialize ⇒ Object
Methods included from AttributeMethods
#attribute_missing, #method_missing, #respond_to?, #respond_to_without_attributes?
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class ActiveModel::AttributeMethods
Instance Method Details
#attribute_names ⇒ Object
Returns an array of attribute names as strings
class Person
include ActiveModel::Attributes
attribute :name, :string
attribute :age, :integer
end
person = Person.new
person.attribute_names
# => ["name", "age"]
111 112 113 |
# File 'lib/active_model/attributes.rb', line 111 def attribute_names @attributes.keys end |
#attributes ⇒ Object
Returns a hash of all the attributes with their names as keys and the values of the attributes as values.
class Person
include ActiveModel::Model
include ActiveModel::Attributes
attribute :name, :string
attribute :age, :integer
end
person = Person.new(name: 'Francesco', age: 22)
person.attributes
# => {"name"=>"Francesco", "age"=>22}
95 96 97 |
# File 'lib/active_model/attributes.rb', line 95 def attributes @attributes.to_hash end |
#initialize ⇒ Object
77 78 79 80 |
# File 'lib/active_model/attributes.rb', line 77 def initialize(*) @attributes = self.class._default_attributes.deep_dup super end |