从obj扩展类

2024-06-25 23:46:52 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一些课程:

class Window(object):
    def __init__(self, name):
        self.wind_name = name
    def getWindowName(self):
        return 'wnd' + self.wind_name

class Control(object):
    def __init__(self, name, wnd):
        self.contrl_name = name
        setattr(self, 'getWindowName', wnd.getWindowName)
        setattr(self, 'wind_name', wnd.wind_name)
    def getControlName(self):
        return (self.getWindowName(), 'unk' + self.contrl_name)

class Button(Control):
    def __init__(self, name, wnd):
        super(Button, self).__init__(name, wnd)
    def getControlName(self):
        return (self.getWindowName(), 'btn' + self.contrl_name)

wnd = Window('MyApp')
btnOK = Button('OK', wnd)
btnOK.getControlName() # work ok., return ('wndMyApp', 'btnOK')
btnOK.wind_name = 'NewApp'
btnOK.getControlName() # does not work properly., return ('wndMyApp', 'btnOK')

如何从类Window扩展类Control{}来访问对象{}中的函数{}和字段{}?在

有没有办法不在类控件中创建字段self.wnd = wnd,或者在Window中添加方法setWindowName。。。?在

我无法从类Window继承类Control!这不符合逻辑。在


Tags: nameselfreturninitdefbuttonwindowcontrol
2条回答

Python允许从多个类继承,即

class Button(Control, Window):
    ...

但在这种情况下,您应该确切地知道自己在做什么(说到Pythons方法解析顺序(MRO))。我建议你读这本小书:Python Attributes and Methods。在

可以将属性用于属性

class Window(object):
def __init__(self, name):
    self.wind_name = name

def getWindowName(self):
    return 'wnd' + self.wind_name

class Control(object):
    def __init__(self, name, wnd):
        self.contrl_name = name
        self.wnd = wnd
        setattr(self, 'getWindowName', wnd.getWindowName)

    def get_wind_name(self):
        return self.wnd.wind_name
    def set_wind_name(self, v):
        self.wnd.wind_name = v

    wind_name = property(get_wind_name, set_wind_name)
    def getControlName(self):
        return (self.getWindowName(), 'unk' + self.contrl_name)

class Button(Control):
    def __init__(self, name, wnd):
        super(Button, self).__init__(name, wnd)
    def getControlName(self):
        return (self.getWindowName(), 'btn' + self.contrl_name)

wnd = Window('MyApp')
btnOK = Button('OK', wnd)
print btnOK.getControlName() # work ok., return ('wndMyApp', 'btnOK')
btnOK.wind_name = 'NewApp'
print btnOK.getControlName()

相关问题 更多 >