Importing Assets
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:
| Propiedad | Tipo | Descripción | Predeterminado |
|---|---|---|---|
top | Boolean | Especifica si el script debe inyectarse en la ventana de nivel superior | false |
attributes | Object | Un conjunto de atributos para aplicar al script. | {} |
Ejemplo:
@JavaScript(value = "ws://my-component.js",
attributes = {@Attribute(name = "type", value = "module")})
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")
| Propiedad | Tipo | Descripción | Predeterminado |
|---|---|---|---|
top | Boolean | Especifica si el script debe inyectarse en la ventana de nivel superior | false |
attributes | Object | Atributos para aplicar al script | {} |
id | String | Un ID de recurso único para asegurar una única inyección | "" |
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")
| Propiedad | Tipo | Descripción | Predeterminado |
|---|---|---|---|
top | Boolean | Especifica si el StyleSheet debe inyectarse en la ventana de nivel superior | false |
attributes | Object | Atributos para aplicar al StyleSheet | {} |
Ejemplo:
@StyleSheet(value = "ws://my-component.css",
attributes = {@Attribute(name = "media", value = "screen")})
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)
| Propiedad | Tipo | Descripción | Predeterminado |
|---|---|---|---|
top | Boolean | Especifica si el StyleSheet debe inyectarse en la ventana superior de la página. | false |
attributes | Object | Un conjunto de atributos para aplicar al elemento de estilo. | {} |
id | String | Un ID de recurso único. Si múltiples recursos tienen el mismo ID, se agruparán en un solo elemento de estilo. | "" |
once | Boolean | Determina si el StyleSheet debe inyectarse en la página solo una vez, independientemente de las múltiples instancias de componente. | true |
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ámetro | Descripción |
|---|---|
script | La 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. |
top | Determina si el script debe inyectarse en la parte superior de la página. |
attributes | Un 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ámetro | Descripción |
|---|---|
stylesheet | La 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. |
top | Determina si el StyleSheet debe inyectarse en la parte superior de la página. |
attributes | Un mapa de atributos para establecer para el StyleSheet. |