Zum Hauptinhalt springen

Importing Assets

In ChatGPT öffnen

Assets-Anmerkungen bieten einen erklärenden Ansatz, um externe und integrierte Ressourcen wie JavaScript und CSS statisch innerhalb einer Anwendung einzubetten. Diese Anmerkungen optimieren das Ressourcenmanagement, indem sie sicherstellen, dass Abhängigkeiten in der richtigen Ausführungsphase geladen werden, was die manuelle Konfiguration reduziert und die Wartbarkeit verbessert.

Importieren von JavaScript-Dateien

Die erklärende JavaScript-Einbindung wird durch die @JavaScript-Anmerkung unterstützt, die ein automatisches Laden von Abhängigkeiten ermöglicht. Die Anmerkung kann sowohl auf Komponentenebene als auch auf Anwendungsebene angewendet werden.

@JavaScript("ws://js/app.js")
@JavaScript("https://cdn.example.com/library.js")

Die Anmerkung akzeptiert einen relativen oder vollständigen Pfad, der in die Anwendung geladen werden soll. Dies wird als <script> Tag in das DOM eingefügt. Darüber hinaus unterstützt die Anmerkung die folgenden Eigenschaften:

EigenschaftTypBeschreibungStandard
topBooleanGibt an, ob das Skript in das oberste Fenster eingefügt werden sollfalse
attributesObjectEine Menge von Attributen, die auf das Skript angewendet werden sollen.{}

Beispiel:

@JavaScript(value = "ws://my-component.js",
attributes = {@Attribute(name = "type", value = "module")})
Info

Dateien werden nur geladen, wenn die Komponente, die die Anmerkung deklariert, an einen Container angehängt ist. Wenn mehrere Komponenten dieselbe Datei laden, wird die Datei nur einmal eingefügt.

Injizieren von JavaScript

In einigen Fällen möchten Sie möglicherweise JavaScript-Code direkt in das DOM injizieren, anstatt einen JavaScript-Pfad bereitzustellen. Die InlineJavaScript-Anmerkung ermöglicht es Ihnen, JavaScript-Inhalte zu injizieren.

@InlineJavaScript("alert('Ich bin ein Inline-Script!');")
@JavaScript("context://js/app.js")
EigenschaftTypBeschreibungStandard
topBooleanGibt an, ob das Skript in das oberste Fenster eingefügt werden sollfalse
attributesObjectAttribute, die auf das Skript angewendet werden sollen{}
idStringEine eindeutige Ressourcen-ID, um eine einzelne Injektion zu gewährleisten""
Warnung

Skripte können mehrfach mit InlineJavaScript injiziert werden, es sei denn, eine spezifische ID wird mit der id-Eigenschaft zugewiesen.

Importieren von CSS-Dateien

Die erklärende CSS-Einbindung wird durch die @StyleSheet-Anmerkung unterstützt, die ein automatisches Laden von Abhängigkeiten ermöglicht. Die Anmerkung kann sowohl auf Komponentenebene als auch auf Anwendungsebene angewendet werden.

@StyleSheet("ws://css/app.css")
@StyleSheet("https://cdn.example.com/library.css")
EigenschaftTypBeschreibungStandard
topBooleanGibt an, ob das Stylesheet in das oberste Fenster eingefügt werden sollfalse
attributesObjectAttribute, die auf das Stylesheet angewendet werden sollen{}

Beispiel:

@StyleSheet(value = "ws://my-component.css",
attributes = {@Attribute(name = "media", value = "screen")})
Info

Dateien werden nur geladen, wenn die Komponente, die die Anmerkung deklariert, an einen Container angehängt ist. Jede Datei wird nur einmal geladen.

Injizieren von CSS

Die InlineStyleSheet-Anmerkung ermöglicht es Ihnen, CSS-Inhalte direkt in eine Webseite auf Komponentenebene und Anwendungsebene einzufügen.

@InlineStyleSheet("body { background-color: lightblue; }")
@InlineStyleSheet(value = "h1 { color: red; }", id = "headingStyles", once = true)
EigenschaftTypBeschreibungStandard
topBooleanGibt an, ob das Stylesheet in das oberste Fenster der Seite eingefügt werden soll.false
attributesObjectEine Menge von Attributen, die auf das Stilelement angewendet werden sollen.{}
idStringEine eindeutige Ressourcen-ID. Wenn mehrere Ressourcen dieselbe ID haben, werden sie in einem einzigen Stilelement zusammengeführt.""
onceBooleanBestimmt, ob das Stylesheet nur einmal in die Seite eingefügt werden soll, unabhängig von mehreren Instanzen der Komponente.true
Tipp

Für eine bessere Syntaxhervorhebung beim Schreiben von Inline-CSS für Ihre Komponenten können Sie die webforJ VS Code-Erweiterung verwenden: Java HTML CSS Syntax Highlighting.

Dynamische Assets zur Laufzeit

Das dynamische Ressourcenmanagement ist durch programmatische Injektion von JavaScript und CSS zur Laufzeit möglich. Sie können Ressourcen basierend auf dem Kontext zur Laufzeit laden oder injizieren.

Laden und Injizieren von JavaScript

Laden oder injizieren Sie JavaScript dynamisch zur Laufzeit unter Verwendung der Page API. Dies ermöglicht es Ihnen, Skripte von URLs zu laden oder Inline-Skripte direkt in das DOM zu injizieren.

Page page = Page.getCurrent();

// Laden von JavaScript-Dateien
page.addJavaScript("ws://js/app.js");
page.addJavaScript("https://cdn.example.com/library.js");

// Injizieren von Inline-JavaScript
page.addInlineJavaScript("console.log('Runtime Injection');");
page.addInlineJavaScript("alert('Dieses Skript läuft inline');");
ParameterBeschreibung
scriptDie URL oder der Inline-Skriptinhalt, der injiziert werden soll. URLs, die mit context:// beginnen, verweisen auf den Ressourcenordner der App.
topBestimmt, ob das Skript oben auf der Seite injiziert werden soll.
attributesEine Map von Attributen, die für das Skript gesetzt werden sollen.

Laden und Injizieren von CSS

Laden oder injizieren Sie CSS dynamisch zur Laufzeit unter Verwendung der Page API. Dies ermöglicht es Ihnen, Stylesheets von URLs zu laden oder Inline-Stile direkt in das DOM zu injizieren.

Page page = Page.getCurrent();

// Laden von CSS-Dateien
page.addStyleSheet("ws://css/app.css");
page.addStyleSheet("https://cdn.example.com/library.css");

// Injizieren von Inline-CSS
page.addInlineStyleSheet("body { background-color: lightblue; }");
page.addInlineStyleSheet("h1 { font-size: 24px; color: navy; }");
ParameterBeschreibung
stylesheetDie URL oder der Inline-Stylesheetinhalt, der injiziert werden soll. URLs, die mit context:// beginnen, verweisen auf den Ressourcenordner der App.
topBestimmt, ob das Stylesheet oben auf der Seite injiziert werden soll.
attributesEine Map von Attributen, die für das Stylesheet gesetzt werden sollen.