3

我有这样的课:

class MainClass
  def self.method_one(String)
      puts "#{self.class} a"
  end
  def self.method_two(String)
      puts "#{self.class} a"
  end
end

我有一个继承的类MainClass

class NewClass < MainClass
  #any_mathod should match any method that is called for NewClass call
  def self.any_method(a,b)
     puts "#{self.class} b"
     super(a)
  end
end

有什么方法可以从MainClass运行它们时扩展所有方法NewClass而不重新定义它们NewClass以接受两个参数而不是一个参数,例如:

NewClass.method_one(String1, String2)

它会产生:

#=> NewClass String2
#=> MainClass String1

并在类内处理String1参数。NewClass对于所有方法,附加参数的处理器都是相同的。

4

3 回答 3

2

也许你想要super方法

class A
  def self.method_one(a)
    puts "a is #{a}"
  end
end

class B < A
  (superclass.methods - superclass.superclass.methods).each do |m|
    define_singleton_method(m) do |a, b|
      puts "b is #{b}"
      super(a)
    end
  end
end

B.method_one(5, 10)

# => b is 10
# => a is 5
于 2012-08-08T15:32:07.103 回答
1

试试这个:

class MainClass
    def self.method_one(string)
        puts string
    end
    def self.method_two(string)
        puts string
    end
end


class NewClass < MainClass
    #Iterate through all methods specific to MainClass and redefine
    (self.superclass.public_methods - Object.public_methods).each do |method|
        define_singleton_method method do |string1, string2|
            #Common processing for String1
            puts string1 

            #Call the MainClass method to process String2
            super(string2)
        end
    end
end

NewClass 将遍历 MainClass 中专门定义的所有方法。然后它将为NewClass定义一个处理String1的类方法,然后调用MainClass方法来处理String2。

于 2012-08-08T15:48:10.030 回答
0

另一种方法是放弃继承并改用模块:

module TestModule
  def awesome1
  end
  def awesome2
  end
end

class TestClass
  def self.include mod
    puts (mod.instance_methods - Module.methods).sort
    super
  end
  include TestModule
end

在覆盖的#include 中添加单例方法,如上述答案中所示。

于 2012-08-08T16:20:26.293 回答