1

我想创建一个特殊的设置类Settings。该类应该能够处理用户键入类似Settings.new.method_1.method_2.method_3内容并将其转换为以下内容的情况:

result = nil
if ConfigurationSettings['method_1'].present? 
  result = ConfigurationSettings['method_1'] 
  if result['method_2'].present?
  result = result['method_2']
  ...
end

return result 

当然,我稍后会使其更灵活,以便它可以拥有超过 2/3 的“方法”。

4

3 回答 3

0

其他答案的问题是所有方法都返回“self”,所以如果你想访问嵌套值......

final_value = Settings.new.method_1.method_2.method_3 

您将获得整个设置哈希。

试试这个...

class Settings
  class SubSettings
    def initialize(sub_setting)
      @sub_setting = sub_setting
    end
    def method_missing(method, *arguments, &block)
      if @sub_setting[method].is_a?(Hash)
        SubSettings.new @sub_setting[method]
      else
        @sub_setting[method]
      end
    end
    def answer
      @sub_setting
    end
  end
  def initialize
    @settings = ConfigurationSettings
  end
  def method_missing(method, *arguments, &block)
    SubSettings.new @settings[method]
  end
end

ConfigurationSettings = {level1a: {level2a: {level3a: "hello", level3b: "goodbye"}, level2b: {level3b: "howdy"}}}

result = Settings.new.level1a.level2a.level3b
p result
=> "goodbye"

这样做是采用初始方法并采用 ConfigurationSettings 哈希的关联子哈希并将其存储到类 SubSettings 的新对象中。它应用 next 方法,如果结果是另一个子哈希,它会迭代创建另一个 SubSettings 等。它只在不再看到哈希时返回实际结果。

于 2015-02-13T16:53:19.167 回答
0

method_missing可供您使用,可用于帮助您解决此问题。将此与方法链接结合起来,您就可以开始了。例如:

class Settings
    def method_missing(meth)
        puts "Missing #{meth}"
        self
    end

    def test
        puts "Test"
        self
    end
end

a = Settings.new
a.test
a.test.b
a.b.test
于 2015-02-13T15:26:28.420 回答
0

我想这是您面临的问题:

class Settings
 def abc
   puts "abc"
 end
 def xyz
   puts "xyz"
 end
end

s = Settings.new
s.abc
#abc
# => nil
s.xyz
#xyz
# => nil
s.abc.xyz
#abc
#NoMethodError: undefined method `xyz' for nil:NilClass

这里的问题s.abc是返回nil并被xyz调用nil。您要实现的目标称为Method Chaining。现在,xyz需要一个Settings对象。在这里做的最简单的事情是:

class Settings2
  def abc
    puts "abc"
    self
  end
  def xyz
    puts "xyz"
    self
  end
end

s2 = Settings2.new
s2.abc.xyz
#abc
#xyz
于 2015-02-13T15:15:54.847 回答