Comenzando con Webcomponents
Esta guía conocerás lo esencial para comenzar a desarrollar webcomponents con Atomico
Gracias por estar aquí e iniciarte con Atomico. Hablemos un poco de lo que hoy ofrece atomico:
Agilidad de desarrollo, el enfoque funcional de Atomico simplifica el código en todas las etapas de desarrollo.
Ligero por dentro y por fuera, Atomico te permite crear un componente con menos código y con un bajo impacto de dependencias 3kb Aproximadamente.
Realmente rapido, Atomico posee un buen performance en el browser y una experiencia de desarrollo ágil.
Entendamos el como luce un webcomponent creado con Atomico:
Analicemos el código por partes...
Importación
¿Qué hemos importado?
c
: Función que transforma el componente funcional en un customElement estándar.html
: Función para declarar la plantilla de nuestro componente, también puedes usar JSX.css
: Función que permite crear el CSSStyleSheet(CSS) para nuestro componente siempre y cuando este declare el shadowDom.
Webcomponent
Nuestra función component
recibe todas las props(Propiedades y Atributos) declaradas en component.props
, la función component
declara toda la lógica y plantilla del webcomponent. Una regla importante dentro de Atomico es "todo componente creado con Atomico debe siempre retornar el tag <host>
".
Propiedades y atributos reactivos del webcomponent
Atomico detecta las prop(Propiedades y Atributos) del componente gracias a la asociación del objeto props, esto mediante el uso de índices y valores te permite definir:
índice: Nombre de la propiedad y atributo.
Valor: tipo de la prop.
Del ejemplo podemos inferir que Atomico creará en nuestro webcomponente una propiedad y atributo llamada mensaje y esta solo puede recibir valores del tipo String.
Apariencia del webcomponent.
Atomico detecta los estilos estáticos de tu componente gracias a la asociación de la propiedad styles
:
styles
acepta valores CSSStyleSheet(CSS) de forma individual o en lista, el retorno de la función css
es un CSSStyleSheet estándar, por lo que puede ser compartido fuera de Atomico.
Definición de tu webcomponent
Para crear nuestro customElement estándar deberemos entregar nuestro componente funcional a la función c
del módulo de Atomico, la función c
generará como retorno un customElement que puede ser definido o extendido.
Ejemplo
Last updated