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.route
Next Pagectx.setValue()
KI-Übersetzungshinweis

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

#ctx.router

Eine auf React Router basierende Router-Instanz zur programmatischen Navigation innerhalb von RunJS. Sie wird üblicherweise in Kombination mit ctx.route und ctx.location verwendet.

#Anwendungsfälle

SzenarioBeschreibung
JSBlock / JSFieldNavigation zu Detailseiten, Listenansichten oder externen Links nach einem Klick auf eine Schaltfläche.
Verknüpfungsregeln / EreignisflussAusführen von navigate zu einer Liste oder Detailseite nach erfolgreichem Absenden oder Übergabe eines state an die Zielseite.
JSAction / EreignisbehandlungAusführen der Routen-Navigation innerhalb der Logik von Formularübermittlungen oder Link-Klicks.
AnsichtsnavigationAktualisierung der URL via navigate beim Wechsel des internen Ansichts-Stacks.

Hinweis: ctx.router ist nur in RunJS-Umgebungen mit einem Routing-Kontext verfügbar (z. B. JSBlock innerhalb einer Seite, Flow-Seiten, Ereignisflüsse usw.); in reinen Backend-Kontexten oder Kontexten ohne Routing (z. B. Workflows) kann dieser Wert null sein.

#Typdefinition

router: Router

Router stammt aus @remix-run/router. In RunJS werden Navigationsoperationen wie Springen, Zurückgehen und Aktualisieren über ctx.router.navigate() implementiert.

#Methoden

#ctx.router.navigate()

Navigiert zu einem Zielpfad oder führt eine Zurück-/Aktualisierungsaktion aus.

Signatur:

navigate(to: string | number | null, options?: RouterNavigateOptions): Promise<void>

Parameter:

  • to: Zielpfad (String), relative Position in der Historie (Number, z. B. -1 für Zurück) oder null (zum Aktualisieren der aktuellen Seite).
  • options: Optionale Konfiguration.
    • replace?: boolean: Ob der aktuelle Historieneintrag ersetzt werden soll (Standard ist false, was einen neuen Eintrag hinzufügt).
    • state?: any: State, der an die Zielroute übergeben wird. Diese Daten erscheinen nicht in der URL und können auf der Zielseite über ctx.location.state abgerufen werden. Dies eignet sich für sensible Informationen, temporäre Daten oder Informationen, die nicht in der URL stehen sollten.

#Beispiele

#Einfache Navigation

// Navigation zur Benutzerliste (neuer Historieneintrag, Zurückgehen möglich)
ctx.router.navigate('/admin/users');

// Navigation zu einer Detailseite
ctx.router.navigate(`/admin/users/${recordId}`);

#Historie ersetzen (Kein neuer Eintrag)

// Weiterleitung zur Startseite nach dem Login; der Benutzer kehrt beim Zurückgehen nicht zur Login-Seite zurück
ctx.router.navigate('/admin', { replace: true });

// Ersetzen der aktuellen Seite durch die Detailseite nach erfolgreicher Formularübermittlung
ctx.router.navigate(`/admin/users/${newId}`, { replace: true });

#State übergeben

// Daten bei der Navigation mitführen; die Zielseite ruft diese über ctx.location.state ab
ctx.router.navigate('/admin/users/123', { 
  state: { from: 'dashboard', tab: 'profile' } 
});

#Zurückgehen und Aktualisieren

// Eine Seite zurück
ctx.router.navigate(-1);

// Zwei Seiten zurück
ctx.router.navigate(-2);

// Aktuelle Seite aktualisieren
ctx.router.navigate(null);

#Beziehung zu ctx.route und ctx.location

ZweckEmpfohlene Verwendung
Navigation/Springenctx.router.navigate(path)
Aktuellen Pfad lesenctx.route.pathname oder ctx.location.pathname
Bei der Navigation übergebenen State lesenctx.location.state
Routenparameter lesenctx.route.params

ctx.router ist für „Navigationsaktionen“ zuständig, während ctx.route und ctx.location für den „aktuellen Routenstatus“ verantwortlich sind.

#Hinweise

  • navigate(path) fügt standardmäßig einen neuen Historieneintrag hinzu, sodass Benutzer über die Zurück-Schaltfläche des Browsers zurückkehren können.
  • replace: true ersetzt den aktuellen Historieneintrag, ohne einen neuen hinzuzufügen. Dies eignet sich für Szenarien wie die Weiterleitung nach dem Login oder die Navigation nach einer erfolgreichen Übermittlung.
  • Zum Parameter state:
    • Daten, die über state übergeben werden, erscheinen nicht in der URL, was sie für sensible oder temporäre Daten geeignet macht.
    • Der Zugriff erfolgt über ctx.location.state auf der Zielseite.
    • state wird in der Browser-Historie gespeichert und bleibt bei der Vorwärts-/Rückwärtsnavigation zugänglich.
    • Nach einer harten Aktualisierung der Seite geht der state verloren.

#Verwandte Themen

  • ctx.route: Informationen zur aktuellen Routenübereinstimmung (pathname, params usw.).
  • ctx.location: Aktueller URL-Standort (pathname, search, hash, state); der state wird hier nach der Navigation gelesen.