logologo
Start
Handbuch
Entwicklung
Plugins
API
Startseite
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
Start
Handbuch
Entwicklung
Plugins
API
Startseite
logologo
Überblick
Schnellstart

Feature-Übersicht

Datenabfrage
Diagrammoptionen
Vorschau & Speichern
Kontextvariablen verwenden
Seitenfilter & Verknüpfungen

Erweitert

Datenabfrage im SQL-Modus
Benutzerdefinierte Diagrammkonfiguration
Benutzerdefinierte Interaktionsereignisse
FAQ
Best Practices
Previous PageBenutzerdefinierte Diagrammkonfiguration
Next PageFAQ
KI-Übersetzungshinweis

Diese Dokumentation wurde automatisch von KI übersetzt.

#Benutzerdefinierte Interaktionsereignisse

Schreiben Sie JavaScript im Ereignis-Editor und registrieren Sie Interaktionen über die ECharts-Instanz chart, um Verknüpfungen zu ermöglichen. Dazu gehören beispielsweise das Navigieren zu einer neuen Seite oder das Öffnen eines Drill-down-Dialogs.

clipboard-image-1761489617

#Ereignisse registrieren und deregistrieren

  • Registrieren: chart.on(eventName, handler)
  • Deregistrieren: chart.off(eventName, handler) oder chart.off(eventName), um Ereignisse desselben Namens zu löschen.

Hinweis: Aus Sicherheitsgründen wird dringend empfohlen, ein Ereignis vor der erneuten Registrierung zu deregistrieren!

#Datenstruktur der params-Parameter im Handler

20251026222859

Häufig verwendete Felder sind params.data und params.name.

#Beispiel: Klick zum Hervorheben einer Auswahl

chart.off('click');
chart.on('click', (params) => {
  const { seriesIndex, dataIndex } = params;
  // Aktuellen Datenpunkt hervorheben
  chart.dispatchAction({ type: 'highlight', seriesIndex, dataIndex });
  // Andere Hervorhebungen aufheben
  chart.dispatchAction({ type: 'downplay', seriesIndex });
});

#Beispiel: Klick zum Navigieren

chart.off('click');
chart.on('click', (params) => {
  const order_date = params.data[0]
  
  // Option 1: Interne Navigation ohne vollständiges Neuladen der Seite (empfohlen), nur relativer Pfad erforderlich
  ctx.router.navigate(`/new-path/orders?order_date=${order_date}`)

  // Option 2: Navigation zu externer Seite, vollständige URL erforderlich
  window.location.href = `https://www.host.com/new-path/orders?order_date=${order_date}`

  // Option 3: Externe Seite in neuem Tab öffnen, vollständige URL erforderlich
  window.open(`https://www.host.com/new-path/orders?order_date=${order_date}`)
});

#Beispiel: Klick zum Öffnen eines Detail-Dialogs (Drill-down)

chart.off('click');
chart.on('click', (params) => {
  ctx.openView(ctx.model.uid + '-1', {
    mode: 'dialog',
    size: 'large',
    defineProperties: {}, // Kontextvariablen für den neuen Dialog registrieren
  });
});

clipboard-image-1761490321

Im neu geöffneten Dialog verwenden Sie die im Diagramm deklarierten Kontextvariablen über ctx.view.inputArgs.XXX.

#Vorschau und Speichern

  • Klicken Sie auf „Vorschau“, um den Ereigniscode zu laden und auszuführen.
  • Klicken Sie auf „Speichern“, um die aktuelle Ereigniskonfiguration zu speichern.
  • Klicken Sie auf „Abbrechen“, um zum zuletzt gespeicherten Zustand zurückzukehren.

Empfehlungen:

  • Verwenden Sie immer chart.off('event') vor dem Binden, um doppelte Ausführungen oder erhöhten Speicherverbrauch zu vermeiden.
  • Verwenden Sie in Ereignis-Handlern möglichst leichte Operationen (z. B. dispatchAction, setOption), um das Blockieren des Rendering-Prozesses zu vermeiden.
  • Validieren Sie die Ereignisbehandlung anhand der Diagrammoptionen und Datenabfragen, um sicherzustellen, dass die verwendeten Felder mit den aktuellen Daten übereinstimmen.