logologo
Start
Handbuch
Entwicklung
Plugins
API
Startseite
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
Start
Handbuch
Entwicklung
Plugins
API
Startseite
logologo
RunJS Übersicht
Module importieren
Rendern im Container

Globale Variablen

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()
KI-Übersetzungshinweis

Dieses Dokument wurde von KI übersetzt. Für genaue Informationen lesen Sie bitte die englische Version.

#ctx.off()

Entfernt Ereignis-Listener, die über ctx.on(eventName, handler) registriert wurden. Es wird häufig in Verbindung mit ctx.on verwendet, um Abonnements zum richtigen Zeitpunkt zu kündigen und so Speicherlecks oder mehrfache Auslösungen zu vermeiden.

#Anwendungsfälle

SzenarioBeschreibung
React useEffect BereinigungAufruf innerhalb der useEffect-Bereinigungsfunktion (Cleanup), um Listener zu entfernen, wenn die Komponente unmountet.
JSField / JSEditableFieldKündigen des Abonnements von js-field:value-change während der bidirektionalen Datenbindung für Felder.
RessourcenbezogenKündigen von Abonnements für Listener wie refresh oder saved, die über ctx.resource.on registriert wurden.

#Typdefinition

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

#Beispiele

#Paarweise Verwendung in 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);
}, []);

#Abbestellen von Ressourcen-Ereignissen

const handler = () => { /* ... */ };
ctx.resource?.on('refresh', handler);
// Zum angemessenen Zeitpunkt
ctx.resource?.off('refresh', handler);

#Hinweise

  1. Konsistente Handler-Referenz: Der an ctx.off übergebene handler muss dieselbe Referenz sein wie der in ctx.on verwendete; andernfalls kann er nicht korrekt entfernt werden.
  2. Rechtzeitige Bereinigung: Rufen Sie ctx.off auf, bevor die Komponente unmountet oder der Kontext zerstört wird, um Speicherlecks zu vermeiden.

#Verwandte Dokumente

  • ctx.on – Ereignisse abonnieren
  • ctx.resource – Ressourcen-Instanz und deren on/off-Methoden