Importing Assets
Las anotaciones de recursos proporcionan un enfoque declarativo para incrustar recursos externos e internos como JavaScript y CSS dentro de una aplicación de forma estática. Estas anotaciones optimizan la gestión de recursos al garantizar que las dependencias se carguen en la fase de ejecución apropiada, reduciendo la configuración manual y mejorando la capacidad de mantenimiento.
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 se puede aplicar 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 ser inyectado 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 de 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 ser inyectado en la ventana de nivel superior | false |
attributes | Object | Atributos para aplicar al script | {} |
id | String | Un ID de recurso único para garantizar una única inyección | "" |
Los scripts se pueden inyectar 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 se puede aplicar 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 la Hoja de Estilos debe ser inyectada en la ventana de nivel superior | false |
attributes | Object | Atributos para aplicar a la Hoja de Estilos | {} |
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 la Hoja de Estilos debe ser inyectada en la ventana de nivel 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 la Hoja de Estilos debe ser inyectada en la página solo una vez, independientemente de múltiples instancias de componente. | true |
Para una mejor resaltación de sintaxis al escribir CSS en línea para sus componentes, puede utilizar la extensión webforJ para VS Code: Java HTML CSS Syntax Highlighting.
Recursos 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 basados en el contexto de tiempo de ejecución.
Cargando e inyectando JavaScript
Cargue o inyecte JavaScript dinámicamente en tiempo de ejecución utilizando la API de Page
. Esto le permite cargar scripts desde URL 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 contenido de script en línea a inyectar. Las URL que comienzan con context:// se resuelven en la carpeta de recursos raíz de la aplicación. |
top | Determina si el script debe ser inyectado 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 dinámicamente en tiempo de ejecución utilizando la API de Page
. Esto le permite cargar hojas de estilo desde URL 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 contenido de Hoja de Estilos en línea a inyectar. Las URL que comienzan con context:// se resuelven en la carpeta de recursos raíz de la aplicación. |
top | Determina si la Hoja de Estilos debe ser inyectada en la parte superior de la página. |
attributes | Un mapa de atributos para establecer para la Hoja de Estilos. |