Saltar al contenido principal

Importing Assets

Abrir en ChatGPT

Las anotaciones de activos proporcionan un enfoque declarativo para incrustar recursos externos y en línea como JavaScript y CSS dentro de una aplicación de manera estática. Estas anotaciones optimizan la gestión de recursos al asegurar que las dependencias se carguen en la fase de ejecución apropiada, reduciendo la configuración manual y mejorando la mantenibilidad.

Importando archivos JavaScript

La inclusión declarativa de JavaScript es compatible a través de la anotación @JavaScript, que permite la carga automática de dependencias. La anotación puede aplicarse tanto a nivel de componente como a nivel de aplicación.

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

La anotación acepta una ruta relativa o completa que se cargará en la aplicación. Esto se insertará en el DOM como una etiqueta <script>. Además, la anotación admite las siguientes propiedades:

PropiedadTipoDescripciónPredeterminado
topBooleanEspecifica si el script debe inyectarse en la ventana de nivel superiorfalse
attributesObjectUn conjunto de atributos para aplicar al script.{}

Ejemplo:

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

Los archivos se cargan solo cuando el componente que declara la anotación está adjunto a un contenedor. Si varios componentes cargan el mismo archivo, el archivo se inyecta solo una vez.

Inyectando JavaScript

En algunos casos, es posible que desee inyectar código JavaScript directamente en el DOM en lugar de proporcionar una ruta de JavaScript. La anotación InlineJavaScript le permite inyectar contenido JavaScript.

@InlineJavaScript("alert('¡Soy un script en línea!');")
@JavaScript("context://js/app.js")
PropiedadTipoDescripciónPredeterminado
topBooleanEspecifica si el script debe inyectarse en la ventana de nivel superiorfalse
attributesObjectAtributos para aplicar al script{}
idStringUn ID de recurso único para asegurar una única inyección""
advertencia

Los scripts pueden inyectarse múltiples veces utilizando InlineJavaScript a menos que se asigne un ID específico utilizando la propiedad id.

Importando archivos CSS

La inclusión declarativa de CSS es compatible a través de la anotación @StyleSheet, que permite la carga automática de dependencias. La anotación puede aplicarse tanto a nivel de componente como a nivel de aplicación.

@StyleSheet("ws://css/app.css")
@StyleSheet("https://cdn.example.com/library.css")
PropiedadTipoDescripciónPredeterminado
topBooleanEspecifica si el StyleSheet debe inyectarse en la ventana de nivel superiorfalse
attributesObjectAtributos para aplicar al StyleSheet{}

Ejemplo:

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

Los archivos se cargan solo cuando el componente que declara la anotación está adjunto a un contenedor. Cada archivo se carga solo una vez.

Inyectando CSS

La anotación InlineStyleSheet le permite inyectar contenido CSS directamente en una página web tanto a nivel de componente como a nivel de aplicación.

@InlineStyleSheet("body { background-color: lightblue; }")
@InlineStyleSheet(value = "h1 { color: red; }", id = "headingStyles", once = true)
PropiedadTipoDescripciónPredeterminado
topBooleanEspecifica si el StyleSheet debe inyectarse en la ventana superior de la página.false
attributesObjectUn conjunto de atributos para aplicar al elemento de estilo.{}
idStringUn ID de recurso único. Si múltiples recursos tienen el mismo ID, se agruparán en un solo elemento de estilo.""
onceBooleanDetermina si el StyleSheet debe inyectarse en la página solo una vez, independientemente de las múltiples instancias de componente.true
sugerencia

Para una mejor resaltación de sintaxis al escribir CSS en línea para sus componentes, puede usar la extensión webforJ de VS Code: Java HTML CSS Syntax Highlighting.

Activos dinámicos en tiempo de ejecución

La gestión dinámica de recursos es posible a través de la inyección programática de JavaScript y CSS en tiempo de ejecución. Puede cargar o inyectar recursos en función del contexto de tiempo de ejecución.

Cargando e inyectando JavaScript

Cargue o inyecte JavaScript de manera dinámica en tiempo de ejecución utilizando la API Page. Esto le permite cargar scripts desde URLs o inyectar scripts en línea directamente en el DOM.

Page page = Page.getCurrent();

// Cargando archivos JavaScript
page.addJavaScript("ws://js/app.js");
page.addJavaScript("https://cdn.example.com/library.js");

// Inyectando JavaScript en línea
page.addInlineJavaScript("console.log('Inyección en tiempo de ejecución');");
page.addInlineJavaScript("alert('Este script se ejecuta en línea');");
ParámetroDescripción
scriptLa URL o el contenido del script en línea para inyectar. Las URLs que comienzan con context:// se resuelven en la carpeta de recursos raíz de la aplicación.
topDetermina si el script debe inyectarse en la parte superior de la página.
attributesUn mapa de atributos para establecer para el script.

Cargando e inyectando CSS

Cargue o inyecte CSS de manera dinámica en tiempo de ejecución utilizando la API Page. Esto le permite cargar hojas de estilo desde URLs o inyectar estilos en línea directamente en el DOM.

Page page = Page.getCurrent();

// Cargando archivos CSS
page.addStyleSheet("ws://css/app.css");
page.addStyleSheet("https://cdn.example.com/library.css");

// Inyectando CSS en línea
page.addInlineStyleSheet("body { background-color: lightblue; }");
page.addInlineStyleSheet("h1 { font-size: 24px; color: navy; }");
ParámetroDescripción
stylesheetLa URL o el contenido de StyleSheet en línea para inyectar. Las URLs que comienzan con context:// se resuelven en la carpeta de recursos raíz de la aplicación.
topDetermina si el StyleSheet debe inyectarse en la parte superior de la página.
attributesUn mapa de atributos para establecer para el StyleSheet.