0

嗨,我正在尝试了解 django.utils.decorators method_decorator 装饰器。method_decorator 将函数装饰器转换为类方法装饰器。

这个装饰器的来源是(https://github.com/django/django/blob/master/django/utils/decorators.py)

我的示例函数装饰器:

def run_eight_times(myfunc):
    def inner_func(*args, **kwargs):
        for i in range(8):
            myfunc(*args, **kwargs)
    return inner_func

我的示例基类:

class Myclass(object):

    def __init__(self,name,favorite_dish):
        self.name = name
        self.favorite_dish = favorite_dish

    def undecorated_function(self):
        print "%s likes spam in his favorite dish %s" % (self.name,self.favorite_dish)

现在我想创建一个继承类,它使用 django.utils.decorators 方法_decorator 来装饰 Myclass 方法 undecorated_function。为了让 method_decorator 工作,我需要重新定义继承类中的函数。

所以这有效:

class Myrepetitiveclass(Myclass):

    def __init__(self,*args, **kwds):
        Myclass.__init__(self,*args,**kwds)

    @method_decorator(run_eight_times)
    def undecorated_function(self):
        print "%s likes spam in his favorite dish %s" % (self.name,self.favorite_dish) 

noisier_me = Myrepetitiveclass("harijaynoisyclass","moreeggs")
noisier_me.undecorated_function()

我有点困惑,不知道为什么下面的代码不起作用并给出语法错误。

这没有得到正确解释并给出语法错误。

class Myrepetitiveclass(Myclass):

    def __init__(self,*args, **kwds):
        Myclass.__init__(self,*args,**kwds)

    # Why does this not work? and gives a syntax error?

    @method_decorator(run_eight_times)
    self.undecorated_function

如何在不重新定义子类中装饰函数?

4

1 回答 1

1

self在该范围内不存在-它仅存在于方法中,并且仅存在于方法中,因为它是作为第一个参数传递的。

这样做的方法是重写该方法,并简单地调用超类方法:

@method_decorator(run_eight_times)
def undecorated_function(self):
    super(Myrepetitiveclass, self).undecorated_function() 

另外,对您的其他代码有两条评论:__init__如果您只是调用父方法,则没有必要覆盖该方法,但如果您确实需要这样做,您应该super像我在这里所做的那样使用,而不是使用超类本身的名称.

于 2012-03-04T21:42:48.230 回答