26

Pyramid tutorial for UX designで見ました。このデコレータが何であるかはよくわかりませんでした。

その使用法を見たサンプルコード。

def __init__(self, request):
    self.request = request
    renderer = get_renderer("templates/global_layout.pt")
    self.global_template = renderer.implementation().macros['layout']

@reify
def company_name(self):
    return COMPANY

@reify
def site_menu(self):
    new_menu = SITE_MENU[:]
    url = self.request.url
    for menu in new_menu:
        if menu['title'] == 'Home':
            menu['current'] = url.endswith('/')
        else:
            menu['current'] = url.endswith(menu['href'])
    return new_menu

@view_config(renderer="templates/index.pt")
def index_view(self):
    return {"page_title": "Home"}

@view_config(renderer="templates/about.pt", name="about.html")
def about_view(self):
    return {"page_title": "About"}
4

2 に答える 2

40

ソースコードのドキュメントから:

""" この (非データ) 記述子デコレータを使用するメソッドの結果を、最初の呼び出しの後にインスタンス dict に入れ、実質的にデコレータをインスタンス変数に置き換えます。"""

あいまいなメモ帳のブログからの説明は、それをうまくまとめています。

関数が一度だけ呼び出されることを除いて、@property のように機能します。その後、値は通常の属性としてキャッシュされます。これにより、不変であることが意図されているオブジェクトで遅延属性を作成できます。

したがって、投稿したコードでは、 site_menu はキャッシュされたプロパティのようにアクセスできます。

于 2012-05-27T18:42:33.570 に答える
4

ドキュメント文字列(source)によると:

""" Put the result of a method which uses this (non-data)
descriptor decorator in the instance dict after the first call,
effectively replacing the decorator with an instance variable."""
于 2012-05-27T18:40:34.347 に答える