class OpenStruct
Öffentliche Klassenmethoden
Source
# File ext/json/lib/json/add/ostruct.rb, line 13 def self.json_create(object) new(object['t'] || object[:t]) end
Siehe as_json.
Öffentliche Instanzmethoden
Source
# File ext/json/lib/json/add/ostruct.rb, line 33 def as_json(*) klass = self.class.name klass.to_s.empty? and raise JSON::JSONError, "Only named structs are supported!" { JSON.create_id => klass, 't' => table, } end
Die Methoden OpenStruct#as_json und OpenStruct.json_create können verwendet werden, um ein OpenStruct-Objekt zu serialisieren und zu deserialisieren; siehe Marshal.
Die Methode OpenStruct#as_json serialisiert self und gibt einen 2-elementigen Hash zurück, der self repräsentiert
require 'json/add/ostruct' x = OpenStruct.new('name' => 'Rowdy', :age => nil).as_json # => {"json_class"=>"OpenStruct", "t"=>{:name=>'Rowdy', :age=>nil}}
Die Methode JSON.create deserialisiert einen solchen Hash und gibt ein OpenStruct-Objekt zurück
OpenStruct.json_create(x) # => #<OpenStruct name='Rowdy', age=nil>
Source
# File ext/json/lib/json/add/ostruct.rb, line 51 def to_json(*args) as_json.to_json(*args) end
Gibt einen JSON-String zurück, der self repräsentiert
require 'json/add/ostruct' puts OpenStruct.new('name' => 'Rowdy', :age => nil).to_json
Ausgabe
{"json_class":"OpenStruct","t":{'name':'Rowdy',"age":null}}