Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > ostructライブラリ > OpenStructクラス
class OpenStruct
クラスの継承リスト: OpenStruct < Object < Kernel < BasicObject
Abstract
OpenStructのインスタンスに対して未定義なセッターメソッド x= を呼ぶと、 OpenStructクラスのObject#method_missingで捕捉され、インスタンスに属性 x が定義されます。 この挙動によって要素を動的に変更できる構造体として働きます。
require 'ostruct' ab = OpenStruct.new ab.foo = 25 p ab.foo # => 25 ab.bar = 2 p ab.bar # => 2 p ab # => <OpenStruct foo=25, bar=2> ab.delete_field("foo") p ab.foo # => nil p ab # => <OpenStruct bar=2> son = OpenStruct.new({:name=>"Thomas", :age => 3}) p son.name # => "Thomas" p son.age # => 3 son.age += 1 p son.age # => 4 son.items = ["candy","toy"] p son.items # => ["candy","toy"] p son # => #<OpenStruct name="Thomas", age=4, items=["candy", "toy"]>
特異メソッド
new(hash = nil) -> OpenStruct
-
OpenStructオブジェクトを生成。 hashが与えられたとき、それぞれのキーを 生成したオブジェクトの要素にし、値をセットします。
- [PARAM] hash:
- 設定する要素とその値を指定します。 hashにはHashクラスのインスタンス、または配列の配列を用いることができます。
- [EXCEPTION] NoMethodError:
- hashのキーが to_sym メソッドを持たないときに発生します。
require 'ostruct' some1 = OpenStruct.new({:a =>"a",:b =>"b"}) # => #<OpenStruct b="b", a="a"> some2 = OpenStruct.new([[:a,"a"],[:b,"b"]]) # => #<OpenStruct b="b", a="a">
インスタンスメソッド
delete_field(name) -> object
-
nameで指定された要素を削除。 その後その要素を参照したらnilが返ります。
- [RETURN]
- 削除前の要素の値を返します。
- [PARAM] name:
- 削除する要素を指定。文字列やシンボルを用います。