logologo
スタート
マニュアル
開発
プラグイン
API
ホーム
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
スタート
マニュアル
開発
プラグイン
API
ホーム
logologo
RunJS 概要
モジュールのインポート
コンテナ内でのレンダリング

グローバル変数

window
document
navigator

ctx

ctx.blockModel
ctx.collection
ctx.collectionField
ctx.dataSource
ctx.dataSourceManager
ctx.element
ctx.exit()
ctx.exitAll()
ctx.filterManager
ctx.form
ctx.getModel()
ctx.getValue()
ctx.getVar()
ctx.i18n
ctx.importAsync()
ctx.initResource()
ctx.libs
ctx.location
ctx.logger
ctx.makeResource()
ctx.message
ctx.modal
ctx.model
ctx.notification
ctx.off()
ctx.on()
ctx.openView()
ctx.render()
ctx.request()
ctx.requireAsync()
ctx.resource
ctx.route
ctx.router
ctx.setValue()
ctx.sql
ctx.t()
ctx.view
Previous Pagectx.notification
Next Pagectx.on()
AI翻訳通知

このドキュメントはAIによって翻訳されました。正確な情報については英語版をご参照ください。

#ctx.off()

ctx.on(eventName, handler) を通じて登録されたイベントリスナーを削除します。通常、ctx.on と組み合わせて使用され、適切なタイミングで購読を解除することで、メモリリークや重複トリガーを防ぎます。

#適用シーン

シーン説明
React useEffect のクリーンアップuseEffect のクリーンアップ関数内で呼び出し、コンポーネントのアンマウント時にリスナーを削除します。
JSField / JSEditableFieldフィールドの双方向バインディング時に、js-field:value-change の購読を解除します。
resource 関連ctx.resource.on で登録された refresh や saved などのリスナーの購読を解除します。

#型定義

off(eventName: string, handler: (event?: any) => void): void;

#使用例

#React useEffect でのペア使用

React.useEffect(() => {
  const handler = (ev) => setValue(ev?.detail ?? '');
  ctx.on('js-field:value-change', handler);
  return () => ctx.off('js-field:value-change', handler);
}, []);

#リソースイベントの購読解除

const handler = () => { /* ... */ };
ctx.resource?.on('refresh', handler);
// 適切なタイミングで
ctx.resource?.off('refresh', handler);

#注意事項

  1. handler の参照の一致: ctx.off に渡す handler は、ctx.on 時と同じ参照である必要があります。そうでない場合、正しく削除できません。
  2. 適切なタイミングでのクリーンアップ: メモリリークを避けるため、コンポーネントのアンマウント時やコンテキストの破棄前に ctx.off を呼び出してください。

#関連ドキュメント

  • ctx.on - イベントの購読
  • ctx.resource - リソースインスタンスとその on/off メソッド