※この翻訳ドキュメントはスクリプトによって出力・同期されています。内容が怪しそうな場合はGitHubにissueを追加したり英語の原文の確認をお願いします。
ハンドラのoptions引数の型について¶
このページではイベントハンドラのoptions
引数の型について説明します。
options引数には辞書の型を受け付けることができます¶
以下のコードサンプルのようにoptions
引数は辞書の型の値を受け付けることができます。
from typing import Dict
import apysc as ap
ap.Stage()
def on_timer(e: ap.TimerEvent, options: Dict[str, str]) -> None:
"""
The handler that a timer calls.
Parameters
----------
e : ap.TimerEvent
Event instance.
options : dict
Optional arguments dictionary.
"""
ap.trace(options["msg"])
timer: ap.Timer = ap.Timer(on_timer, delay=1000, options={"msg": "Hello!"})
timer.start()
TypedDictを使った型アノテーションについて¶
通常の辞書の代わりにTypedDict
を使った型アノテーションは可読性の向上に役立つことがあります。apyscではoptions引数にTypedDictによる型アノテーションをサポートしており、実際に渡したoptionsの辞書の型とハンドラのTypedDictによるアノテーション間で型チェックを行うことができます。
from typing_extensions import TypedDict
import apysc as ap
ap.Stage()
class _MsgOptions(TypedDict):
msg: str
def on_timer(e: ap.TimerEvent, options: _MsgOptions) -> None:
"""
The handler that a timer calls.
Parameters
----------
e : ap.TimerEvent
Event instance.
options : dict
Optional arguments dictionary.
"""
ap.trace(options["msg"])
options: _MsgOptions = {"msg": "Hello!"}
timer: ap.Timer = ap.Timer(on_timer, delay=1000, options=options)
timer.start()
特記事項: もしPython3.8もしくはそれ以降のPythonバージョンをお使いの場合にはtyping_extensions
パッケージの代わりにtyping
パッケージからTypedDict
をimportすることができます(例 : from typing import TypedDict
)。