Zum Hauptinhalt springen

Importing Assets

ChatGPT öffnen

Assets-Anmerkungen bieten einen deklarativen Ansatz zur Einbettung externer und interner Ressourcen wie JavaScript und CSS innerhalb einer App auf statische Weise. Diese Anmerkungen optimieren das Ressourcenmanagement, indem sie sicherstellen, dass Abhängigkeiten zur entsprechenden Ausführungsphase geladen werden, was die manuelle Konfiguration reduziert und die Wartbarkeit erhöht.

Importieren von JavaScript-Dateien

Deklarative JavaScript-Einbindung wird durch die @JavaScript-Anmerkung unterstützt, die das automatische Laden von Abhängigkeiten ermöglicht. Die Anmerkung kann sowohl auf Komponenten- als auch auf App-Ebene 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 der App geladen werden soll. Dies wird in das DOM als <script>-Tag 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
attributesObjektEine Menge von Attributen, die auf das Skript angewendet werden.{}

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 anzugeben. Die Anmerkung InlineJavaScript ermöglicht Ihnen das Injizieren von JavaScript-Inhalten.

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

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

Importieren von CSS-Dateien

Die deklarative CSS-Einbindung wird durch die @StyleSheet-Anmerkung unterstützt, die das automatische Laden von Abhängigkeiten ermöglicht. Die Anmerkung kann sowohl auf Komponenten- als auch auf App-Ebene 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
attributesObjektAttribute, die auf das Stylesheet angewendet werden{}

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 Anmerkung InlineStyleSheet ermöglicht es Ihnen, CSS-Inhalte direkt in eine Webseite auf Komponenten- und App-Ebene 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 sollfalse
attributesObjektEine Menge von Attributen, die auf das Style-Element angewendet werden.{}
idStringEine eindeutige Ressourcen-ID. Wenn mehrere Ressourcen dieselbe ID haben, werden sie in einem einzigen Style-Element zusammengefasst.""
onceBooleanBestimmt, ob das Stylesheet nur einmal in die Seite injiziert werden soll, unabhängig von mehreren Komponenteninstanzen.true
Info

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

Dynamische Ressourcen zur Laufzeit

Dynamisches Ressourcenmanagement ist durch programmgesteuertes Injizieren von JavaScript und CSS zur Laufzeit möglich. Sie können Ressourcen basierend auf dem Laufzeitkontext laden oder injizieren.

Laden und Injizieren von JavaScript

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

Page page = Page.getCurrent();

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

// Inline-JavaScript injizieren
page.addInlineJavaScript("console.log('Runtime Injection');");
page.addInlineJavaScript("alert('Dieses Skript wird inline ausgeführt');");
ParameterBeschreibung
scriptDie URL oder der Inline-Skriptinhalt, der injiziert werden soll. URLs, die mit context:// beginnen, lösen sich im Ressourcenordner der App auf.
topBestimmt, ob das Skript oben auf der Seite injiziert werden soll.
attributesEine Karte von Attributen, die für das Skript festgelegt werden sollen.

Laden und Injizieren von CSS

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

Page page = Page.getCurrent();

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

// Inline-CSS injizieren
page.addInlineStyleSheet("body { background-color: lightblue; }");
page.addInlineStyleSheet("h1 { font-size: 24px; color: navy; }");
ParameterBeschreibung
stylesheetDie URL oder der Inline-Stylesheet-Inhalt, der injiziert werden soll. URLs, die mit context:// beginnen, lösen sich im Ressourcenordner der App auf.
topBestimmt, ob das Stylesheet oben auf der Seite injiziert werden soll.
attributesEine Karte von Attributen, die für das Stylesheet festgelegt werden sollen.