如何在Ruby中动态扩展/修改继承类的所有方法?
我有一门课是这样的:如何在Ruby中动态扩展/修改继承类的所有方法?,ruby,Ruby,我有一门课是这样的: 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 t
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
它将产生:
#=> NewClass String2
#=> MainClass String1
并在
NewClass
类中处理String1
参数。附加参数的处理器对于所有方法都是相同的。也许您想要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
A类
定义自我方法(a)
把“a是{a}”
结束
结束
B类b是10
#=>a是5
试试这个:
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
class类main类
定义自我方法(字符串)
放线
结束
定义自身方法二(字符串)
放线
结束
结束
类NewClass
NewClass将遍历MainClass中专门定义的所有方法。然后,它将为处理String1的NewClass定义一个类方法,然后调用MainClass方法来处理String2。另一种方法是放弃继承,改用模块:
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中添加单例方法,如上面的答案所示。是的,但是不在“B”类中定义一个方法,是否可以以某种方式这样做?
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