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.message
Next Pagectx.model
KI-Übersetzungshinweis

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

#ctx.modal

Eine auf Ant Design Modal basierende Shortcut-API, die verwendet wird, um in RunJS aktiv Modal-Fenster (Informationshinweise, Bestätigungs-Popups usw.) zu öffnen. Sie wird durch ctx.viewer / das Ansichtssystem implementiert.

#Anwendungsfälle

SzenarioBeschreibung
JSBlock / JSFieldAnzeige von Operationsergebnissen, Fehlermeldungen oder Zweitbestätigungen nach Benutzerinteraktionen.
Workflow / AktionsereignissePopup-Bestätigung vor dem Absenden; Beenden nachfolgender Schritte über ctx.exit(), falls der Benutzer abbricht.
VerknüpfungsregelnPopup-Hinweise für den Benutzer, wenn die Validierung fehlschlägt.

Hinweis: ctx.modal ist in RunJS-Umgebungen mit einem Ansichtskontext verfügbar (z. B. JS-Blöcke innerhalb einer Seite, Workflows usw.); in Backend- oder Nicht-UI-Kontexten existiert es möglicherweise nicht. Es wird empfohlen, beim Aufruf die optionale Verkettung (ctx.modal?.confirm?.()) zu verwenden.

#Typdefinition

modal: {
  info: (config: ModalConfig) => Promise<void>;
  success: (config: ModalConfig) => Promise<void>;
  error: (config: ModalConfig) => Promise<void>;
  warning: (config: ModalConfig) => Promise<void>;
  confirm: (config: ModalConfig) => Promise<boolean>;  // Gibt true zurück, wenn der Benutzer auf OK klickt, false beim Abbrechen
};

ModalConfig entspricht der Konfiguration der statischen Methoden von Ant Design Modal.

#Gängige Methoden

MethodeRückgabewertBeschreibung
info(config)Promise<void>Informationshinweis-Modal
success(config)Promise<void>Erfolgshinweis-Modal
error(config)Promise<void>Fehlermeldung-Modal
warning(config)Promise<void>Warnhinweis-Modal
confirm(config)Promise<boolean>Bestätigungs-Modal; gibt true zurück, wenn der Benutzer auf OK klickt, und false, wenn er abbricht.

#Konfigurationsparameter

Konsistent mit Ant Design Modal, zu den gängigen Feldern gehören:

ParameterTypBeschreibung
titleReactNodeTitel
contentReactNodeInhalt
okTextstringText der Bestätigungsschaltfläche
cancelTextstringText der Abbrechen-Schaltfläche (nur für confirm)
onOk() => void | Promise<void>Wird beim Klicken auf OK ausgeführt
onCancel() => voidWird beim Klicken auf Abbrechen ausgeführt

#Beziehung zu ctx.message und ctx.openView

VerwendungszweckEmpfohlene Nutzung
Leichtgewichtiger temporärer Hinweisctx.message, verschwindet automatisch
Info-/Erfolgs-/Fehler-/Warnungs-Modalctx.modal.info / success / error / warning
Zweitbestätigung (erfordert Benutzerwahl)ctx.modal.confirm, zusammen mit ctx.exit() zur Steuerung des Ablaufs
Komplexe Interaktionen wie Formulare oder Listenctx.openView zum Öffnen einer benutzerdefinierten Ansicht (Seite/Drawer/Modal)

#Beispiele

#Einfaches Informations-Modal

ctx.modal.info({
  title: 'Hinweis',
  content: 'Vorgang abgeschlossen',
});

#Bestätigungs-Modal und Ablaufsteuerung

const confirmed = await ctx.modal.confirm({
  title: 'Löschen bestätigen',
  content: 'Sind Sie sicher, dass Sie diesen Datensatz löschen möchten?',
  okText: 'Bestätigen',
  cancelText: 'Abbrechen',
});
if (!confirmed) {
  ctx.exit();  // Beendet nachfolgende Schritte, wenn der Benutzer abbricht
  return;
}
await ctx.runAction('destroy', { filterByTk: ctx.record?.id });

#Bestätigungs-Modal mit onOk

await ctx.modal.confirm({
  title: 'Einreichung bestätigen',
  content: 'Änderungen können nach dem Absenden nicht mehr bearbeitet werden. Möchten Sie fortfahren?',
  async onOk() {
    await ctx.form.submit();
  },
});

#Fehlermeldung

try {
  await someOperation();
  ctx.modal.success({ title: 'Erfolg', content: 'Vorgang abgeschlossen' });
} catch (e) {
  ctx.modal.error({ title: 'Fehler', content: e.message });
}

#Verwandte Themen

  • ctx.message: Leichtgewichtiger temporärer Hinweis, verschwindet automatisch
  • ctx.exit(): Wird häufig als if (!confirmed) ctx.exit() verwendet, um den Ablauf zu beenden, wenn ein Benutzer die Bestätigung abbricht
  • ctx.openView(): Öffnet eine benutzerdefinierte Ansicht, geeignet für komplexe Interaktionen