Dieses Dokument wurde von KI übersetzt. Für genaue Informationen lesen Sie bitte die englische Version.
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.
| Szenario | Beschreibung |
|---|---|
| JSBlock / JSField | Navigation zu Detailseiten, Listenansichten oder externen Links nach einem Klick auf eine Schaltfläche. |
| Verknüpfungsregeln / Ereignisfluss | Ausführen von navigate zu einer Liste oder Detailseite nach erfolgreichem Absenden oder Übergabe eines state an die Zielseite. |
| JSAction / Ereignisbehandlung | Ausführen der Routen-Navigation innerhalb der Logik von Formularübermittlungen oder Link-Klicks. |
| Ansichtsnavigation | Aktualisierung der URL via navigate beim Wechsel des internen Ansichts-Stacks. |
Hinweis:
ctx.routerist 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.
Router stammt aus @remix-run/router. In RunJS werden Navigationsoperationen wie Springen, Zurückgehen und Aktualisieren über ctx.router.navigate() implementiert.
Navigiert zu einem Zielpfad oder führt eine Zurück-/Aktualisierungsaktion aus.
Signatur:
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.| Zweck | Empfohlene Verwendung |
|---|---|
| Navigation/Springen | ctx.router.navigate(path) |
| Aktuellen Pfad lesen | ctx.route.pathname oder ctx.location.pathname |
| Bei der Navigation übergebenen State lesen | ctx.location.state |
| Routenparameter lesen | ctx.route.params |
ctx.router ist für „Navigationsaktionen“ zuständig, während ctx.route und ctx.location für den „aktuellen Routenstatus“ verantwortlich sind.
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.state:
state übergeben werden, erscheinen nicht in der URL, was sie für sensible oder temporäre Daten geeignet macht.ctx.location.state auf der Zielseite.state wird in der Browser-Historie gespeichert und bleibt bei der Vorwärts-/Rückwärtsnavigation zugänglich.state verloren.state wird hier nach der Navigation gelesen.