Manual de Web Components
Manual de Web Components
Manual de Web Components
http://desarrolloweb.com/manuales/web-components.html Pgina 1 de 40
Manual de Web Components
En este manual vamos a conocer el nuevo estndar de los Web Components, una nueva tecnologa
implementada en navegadores modernos que permitir llevar la web a un nuevo nivel.
Web Components incluye cuatro especificaciones que nos van a servir para cambiar radicalmente el modo
en el que construimos las pginas web, aportando nuevas herramientas capaces de extender el lenguaje
HTML. Las veremos por separado y luego las utilizaremos en conjunto.
Los componentes, tambin llamados Custom Elements, son el corazn y objetivo final de este estndar y
tienen como objetivo construir nuevos elementos para el lenguaje HTML. stos son como etiquetas HTML
nuevas que puedes desarrollar t mismo con muy poco esfuerzo, de modo que puedas realizar componentes
para implementar cualquier tipo de tarea en el mbito de una web, interfaz de usuario, etc.
Como Web Components es un estndar, podemos desarrollar directamente con Javascript y no estaremos
obligados a usar alguna librera o framework adicional. En este manual nos centraremos en esta posibilidad,
usar Web Components con Javascript estndar.
Por todo ello es una tecnologa que ya podemos usar y beneficiarnos de extraordinarias posibilidades. En
este manual vamos a recorrer diversos puntos del estndar para explicarlo, de modo que los desarrolladores
puedan aprender y comenzar a usar Web Components.
http://desarrolloweb.com/manuales/web-components.html Pgina 2 de 40
Manual de Web Components
Las siguientes personas han participado como autores escribiendo artculos de este manual.
http://desarrolloweb.com/manuales/web-components.html Pgina 3 de 40
Manual de Web Components
Web Components es un estndar de la W3C que est siendo definido en el momento de escribir este
manual. Explicaremos con detalle en qu consiste el estndar y su filosofa.
Las especificaciones estn a distintos niveles de finalizacin pero, como ya se encuentran publicados sus
borradores, varios navegadores las vienen implementando. Todos los navegadores en algn momento se
adaptarn para soportar Web Components, pero para los navegadores antiguos explicaremos cmo usar el
Polyfill, que nos aporta compatibilidad entre los clientes web que no lo implementan todava.
En este artculo vamos a realizar una introduccin terica a lo que son los Web Components, una
revolucin en el mundo del desarrollo para la web que poco a poco se est concretando, a la vez que va
adquiriendo ms soporte por parte de los navegadores.
Libreras como Polymer estn dando que hablar ltimamente, que nos sirven para crear Web Components.
Otras libreras como AngularJS con sus directivas tambin evocan de manera particular a los Web
Components, aunque para ser exactos el estndar es bastante ms abarcante de lo que muchas personas
piensan cuando se nombra la tecnologa.
Vamos a comenzar explicando el objetivo que vienen a cubrir los Web Components y luego trataremos
acerca de las 4 especificaciones que podemos encontrar en esta tecnologa.
Los Web Components nos ofrecen un estndar que va enfocado a la creacin de todo tipo de componentes
utilizables en una pgina web, para realizar interfaces de usuario y elementos que nos permitan presentar
informacin (o sea, son tecnologas que se desarrollan en el lado del cliente). Los propios desarrolladores
sern los que puedan, en base a las herramientas que incluye Web Components crear esos nuevos elementos
y publicarlos para que otras personas tambin los puedan usar.
http://desarrolloweb.com/manuales/web-components.html Pgina 4 de 40
Manual de Web Components
En resumen, este nuevo estndar viene a facilitar la creacin de nuevos elementos que enriquezcan la web.
Pero adems, est pensado para que se puedan reutilizar de una manera sencilla y tambin extender, de
modo que seamos capaces de crear unos componentes en base a otros.
Como veremos, al disearse los estndares para los Web Components tambin se ha procurado que se
pueda trabajar con los componentes de manera aislada, permitiendo que las nuevas piezas puedan usarse en
el contexto de una web sin que afecten a otras ya existentes. Paralelamente se ha tratado de que el proceso
de cargar un nuevo componente en una pgina se pueda realizar de manera atmica (un solo bloque) en
lugar de como se suele hacer con muchas libreras y plugins actuales que requieren de escribir los estilos por
una parte y el javascript por otra.
Nota: El W3C est encargado de mantener los estndares, pero lo cierto es que sus procedimientos para
permitir la evolucin de la web son un poco pesados. Nos referimos a que los desarrolladores
habitualmente detectamos necesidades mucho antes que la W3C realice un estndar para poder
cubrirlas. De hecho, pueden pasar aos desde que algo comienza a ser usado en el mundo de la web
hasta que se presenta el estndar. En resumen, el mundo de la web va mucho ms rpido que la
definicin de los estndares.
El ejemplo ms tpico que veremos por ah es un mapa de Google. Hoy, si no usamos web components,
cuando queremos mostrar un mapa en una pgina web, tenemos que crear cdigo en tres bloques.
Otro ejemplo sera un calendario, que necesitas de nuevo bsicamente tres partes:
Son tres lenguajes diferentes, que se especifican en bloques de cdigo separados y usualmente en archivos
separados. Sin Web Components, para tener todos los bloques agrupados y tener un cdigo nico para
embeber un elemento se usaba generalmente la etiqueta IFRAME, que permite cargar un HTML, CSS y
Javascript y reducir su mbito a un pequeo espacio de la pgina. Esta tcnica se sigue utilizando, pero en el
futuro se va a sustituir gracias a las bondades de los Web Components.
A partir de ahora podremos expresar un mapa de Google con una etiqueta propietaria, que no pertenece al
estndar del HTML, que simplifica la tarea y la acota a un pequeo bloque independiente.
http://desarrolloweb.com/manuales/web-components.html Pgina 5 de 40
Manual de Web Components
Para incluir un calendario que indique los das que estamos libres u ocupados podremos usar una etiqueta
propietaria en la que indicamos las caractersticas de ese calendario.
<google-calendar-busy-now
calendarId="TU_ID_CAL"
apiKey="TU_LLAVE_API"
busyLabel="Ocupado"
freeLabel="Estoy libre">
</google-calendar-busy-now>
Son dos ejemplos tomados directamente de Web Components reales, creados por el equipo de Google.
Tienen como intencin reflejar:
1. Es como si estuviramos inventando etiquetas nuevas. Esa es una de las capacidades de los Web
Components, pero no la nica.
2. Las etiquetas propietarias que nos estamos inventando son "google-map" y "google-calendar-busy-
now"
3. No tenemos el HTML por un lado, el CSS y el Javascript por otro. Es simplemente la etiqueta
nueva y sta ya es capaz de lanzar el comportamiento.
4. Obviamente, en algn lugar habr un Javascript que se encargar de procesar esa etiqueta, pero ser
genrico para cualquier tipo de mapa y reutilizable. Lo que adems debe verse es que en el HTML
ests colocando informacin que antes estara en el Javascript. Por ejemplo en el caso del mapa de
google los atributos latitude="12.678" longitude="-67.211" antes eran datos que se escriban en el
Javascript. Ahora se declaran en el HTML. El Javascript por tanto es genrico y no tendremos que
programarlo nosotros, sino que nos vendr dado por Google o por el creador del web component
de turno.
Ahora que ya hemos entendido alguna cosa de lo que son los componentes web, el concepto en s, vamos a
ser un poco ms formales y describir las distintas especificaciones que podemos encontrar en los Web
Components.
Custom Elements: Esta especificacin describe el mtodo que nos permitir crear nuevas etiquetas
personalizadas, propietarias. Estas etiquetas las podremos ingeniar para dar respuesta a cualquier necesidad
que podamos tener. Son los casos bsicos que hemos visto en los puntos anteriores de este artculo.
HTML Templates: Incorpora un sistema de templating en el navegador. Los templates pueden contener
tanto HTML como CSS que inicialmente no se mostrar en la pgina. El objetivo es que con Javascript se
acceda al cdigo que hay dentro del template, se manipule si es necesario y posteriormente se incluya, las
veces que haga falta, en otro lugar de la pgina.
HTML Imports: Permite importar un pedazo de cdigo que podrs usar en un lugar de tu pgina. Ese
cdigo podr tener HTML, CSS y Javascript. El HTML no se visualizar directamente en la pgina, pero lo
podras acceder con Javascript e inyectar en algn lugar. Pero aunque se llame especficamente "HTML
Imports", realmente sirve para cargar de una manera nica tanto HTML como CSS como Javascript.
Adems podrs tener dentro un "HTML Template", con las ventajas que ellos aportan. Mendiante cdigo
Javascript seremos capaces tambin de registrar componentes personalizados "Custom Elements" o realizar
http://desarrolloweb.com/manuales/web-components.html Pgina 6 de 40
Manual de Web Components
Shadow DOM: Este sistema permite tener una parte del DOM oculta a otros bloques de la pgina. Se dice
comnmente que estamos encapsulando parte del DOM para que no interfiera con otros elementos de la
pgina. Bsicamente te sirve para solucionar un caso comn que ocurre al incluir un plugin de terceros. A
veces usan clases o identificadores para aplicar estilos que afectan a otros elementos de la pgina,
descolocando cosas que no debera o alterando su aspecto. Pues con el Shadow DOM podemos hacer que
los componentes tengan partes que no estaran visibles desde fuera, pudiendo colocar estilos que solo
afectan al Shadow DOM de un web component y evitando que estilos de la pgina sean capaces de afectar
al Shadow DOM.
Nota: Estas 4 especificaciones, aunque las tengamos por separado, estn encaminadas a trabajar en
conjunto para un mismo fin: poder realizar tus propios componentes para la web. Las veremos ms
adelante con detalle.
No tiene mucha importancia hablar de compatibilidad con navegadores porque cuando leas el artculo
probablemente haya cambiado el panorama. Es una tecnologa que est comenzando y que no est
totalmente implementada en los navegadores, pero lo estar en breve. No obstante, como mencionaremos
despus, hay soluciones. A fecha de publicacin del artculo, noviembre de 2015, podemos resumir la
compatibilidad as:
Custom Elements Estado de la especificacin: Working Draft W3C Soporte total en Chrome, Opera y
Android Browser > 4.4.4 y Chrome para Android 46
HTML Templates Estado de la especificacin: LS (Living Standard, por la Whatwg) Soporte total para
todos los navegadores menos IE y Opera mini (Edge lo aplicar de manera inminente)
HTML Imports Estado de la especificacin: Working Draft W3C Soporte total en Chrome, Opera y
Android Browser > 44 y Chrome para Android 46
Shadow DOM Estado de la especificacin: Working Draft W3C Soporte total en Chrome, Opera y
Android Browser > 4.4 y Chrome para Android 46
Como has podido ver, el que ms soporte le da es Chrome. Otros navegadores como Firefox o Edge
apenas estn empezando, por lo que tendramos que usar algn tipo de Polyfill. De todos modos, para saber
el soporte en el momento actual una rpida consulta a Caniuse.com te ofrecer la informacin actualizada.
En cuanto a libreras Javascript para producir Web Components hay que aclarar primero que realmente no
hacen falta. Como has visto, los Web Components forman parte de un estndar, que est siendo discutido
todava en mayor media, pero es un estndar. Eso quiere decir que, ms tarde o temprano, todos los
navegadores lo tendrn en su "core" y podrs usarlo con tan solo usar Javascript estndar, sin necesidad de
ninguna librera adicional.
http://desarrolloweb.com/manuales/web-components.html Pgina 7 de 40
Manual de Web Components
No obstante, lo cierto es que diversos actores se han apresurado a presentar algunas libreras que nos
permiten desarrollar hoy mismo con la tecnologa de los Web Components. Te las resumimos a
continuacin:
Polymer: Es una librera impulsada por Google que actualmente es el mayor referente en cuanto a Web
Components. Desarrollada para aprovechar la tecnologa del estndar, facilitando la creacin de interfaces
de usuario reutilizables.
X-Tag: Es la apuesta de Mozilla para la creacin de Web Components, especficamente los custom
elements, al alcance de todos los navegadores modernos.
Bosonic: Herramientas y utilidades para crear web components incluso en navegadores no tan nuevos,
como Internet Explorer 9.
Conclusin
Hemos conocido nicamente la punta del iceberg en lo que respecta a web components, pero en breve
analizaremos cada una de las partes de este estndar que va a revolucionar el desarrollo front end.
Muchos sitios estn ya usando partes de las especificaciones de Web Components para producir sus
interfaces e implementar funcionalidad del lado del cliente, como por ejemplo Youtube o Github. No dejes
de usarlo porque no estn totalmente disponibles en los navegadores, puesto que puedes usar los
mencionados polyfills para obtener esa compatibilidad. Te estars preparando para el futuro.
En los prximos artculos vamos a recorrer cada una de las partes de Web Components para ver ejemplos
sobre cmo se implementan, ya en la prctica. Comenzaremos viendo cmo se hace un Custom Element
con Javascript nativo.
Si quieres saber mucho ms y tienes disponible un rato para seguir aprendiendo, tenemos esta presentacin
de Web Components que seguro te gustar y te aportar mucha otra informacin de utilidad para poder
comenzar a usar este estndar.
Para ver este vdeo es necesario visitar el artculo original en: http://desarrolloweb.com/articulos/que-
son-web-components.html
http://desarrolloweb.com/manuales/web-components.html Pgina 8 de 40
Manual de Web Components
Vamos a explicar las cuatro especificaciones del estndar de los Web Components, que bsicamente nos
ofrecen nuevas etiquetas HTML y APIs Javascript para programacin. Se pueden usar por separado, pero la
verdadera potencia se da cuando se juntan para el desarrollo de nuevos elementos. Analizaremos de manera
independiente cada una de las especificaciones que contiene, aportando ejemplos de uso con el cdigo
Javascript necesario para operar con ellas.
En el anterior artculo conocimos qu son los Web Components y por qu estas especificaciones
representan una novedad muy significativa en el mundo del desarrollo de interfaces de usuario y
aplicaciones web del lado del cliente en general.
Conocimos que una de las especificaciones es la de "Custom Elements", que quizs sea la ms
representativa porque es la que nos permite hacer nuevos elementos del HTML, que realizan
funcionalidades personalizadas o presentan informacin de una nueva manera. Adems, estos Custom
Elements los puedes usar directamente en tu pgina, sin necesidad de programacin. Para ser correctos el
desarrollador que crea el custom element generalmente s necesitar realizar tareas de programacin, aunque
todos aquellos que lo usen, lo harn mediante la expresin de una etiqueta, de manera declarativa.
Los Custom Elements no son algo totalmente ajeno al HTML tradicional. Si lo ves bien, un ejemplo de
Custom Element que conocemos de toda la vida es una etiqueta SELECT, que permite definir por medio
de un cdigo HTML sencillo un componente que tiene un comportamiento propio: lo pulsamos y nos
permite ver varias opciones sobre las que podemos escoger una o varias. Esos SELECT los podemos
agrupar con otros campos para hacer componentes mayores, como seran formularios. Obviamente, esos
elementos existen desde toda la vida y no los habamos entendido desde la perspectiva de los web
components, pero nos hacen entender bien en qu se basa esta novedad de los custom elements.
http://desarrolloweb.com/manuales/web-components.html Pgina 9 de 40
Manual de Web Components
En este y en los prximos artculos de este manual vamos a aprender a usar las diferentes especificaciones
de los web componets usando Javascript estndar, o sea, lo que se conoce en el argot de los desarrolladores
como VanillaJS. Es importante porque veremos que para crear nuevos custom elements no necesito
ninguna librera externa al Javascript que ya te soportan de manera nativa los navegadores.
No obstante, debemos insistir en que el desarrollo de web components ser mucho ms rpido si nos
basamos en alguna librera que nos facilite ciertos procesos habituales, principalmente por hacer nuestras
horas de desarrollo ms productivas.
Las libreras como Polymer o X-Tag tambin nos aportan una capa adicional en relacin a la
compatibilidad, adems de optimizar algunos procesos interesantes de cara a crear aplicaciones web ms
rpidas. Es por ello que los ejemplos de este manual tienen un valor ms didctico que otra cosa, ya que
conocer los procesos de Javascript para la creacin de Web Components ayudar mucho a la hora de
entender cmo se realizan usando una librera por encima.
Iremos poco a poco introducindonos en el mundo de los Custom Elements, creando elementos sencillos
que no nos compliquen demasiado la vida inicialmente. Obviamente, de momento no sern los ms
atractivos funcional o estticamente, pero facilitar el aprendizaje.
Nota: Aunque en este artculo usaremos solamente la especificacin de los Custom Elements, lo
habitual es que se usen en conjunto varias, o todas, las especificaciones de Web Components.
Vers que sencillo es esto. Vamos a crear un componente llamado "dw-holamundo". Una vez definido lo
usaremos de esta manera:
<dw-holamundo></dw-holamundo>
Ciertamente, la etiqueta "dw-holamundo" no existe en el HTML, pero gracias a los Web Components la
podemos crear para usarla en nuestra pgina. Es tan sencillo como registrarla, por su nombre, mediante
Javascript.
<script>
document.registerElement('dw-holamundo');
</script>
Ya est! tenemos registrado nuestro primer custom element y sabemos usarlo. Si estabas esperando alguna
complejidad adicional, sentimos decepcionarte.
Nuestro problema es que, tal cual hemos hecho nuestro elemento personalizado, no hace absolutamente
nada. Tendremos que asignarle algn comportamiento, alguna forma, lo que sea, para que realmente tenga
sentido nuestro primer ejemplo. Ahora veremos cmo mejorarlo pero antes quiero que veas el cdigo
fuente de este ejercicio:
http://desarrolloweb.com/manuales/web-components.html Pgina 10 de 40
Manual de Web Components
<p>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<p>No aparece nada porque no le hemos asignado ninguna funcin al Web Component</p>
<dw-holamundo></dw-holamundo>
<script>
document.registerElement('dw-holamundo');
</script>
</body>
</html>
No te est faltando algo? Dnde est el script de la librera que da soporte a los web components? (es una
pregunta con trampa)
La respuesta ya la debes saber, porque lo hemos comentado. Web Components es algo que funciona tal cual
en los navegadores, Javascript puro y estndar. No obstante, quizs hayas pensado en la necesidad de usar
un Polyfill, para que los navegadores antiguos puedan entender estas sentencias nuevas de Javascript.
Nota: El tema de los Polyfill lo veremos con detalle ms adelante, pero de momento tenemos que
comentar que este cdigo lo vas a poder ejecutar sin problemas en Chrome, que es el navegador, junto
con Opera, que ms adelantada lleva la incorporacin de este estndar a su motor de Javascript. En un
breve espacio de tiempo otros navegadores modernos tendrn total soporte a estas sentencias porque,
insistimos, es Javascript nativo. Tambin tienes ms informacin en el artculo sobre qu son los Web
Components.
Para aplicar algn comportamiento especfico a nuestro primer web component se nos complica un poco el
cdigo, porque requerimos de varios pasos. Realmente son pocas sentencias con las que esperamos te
familiarizars rpidamente.
http://desarrolloweb.com/manuales/web-components.html Pgina 11 de 40
Manual de Web Components
comportamientos cuando se estn creando los elementos. Existen varios eventos a los que podemos
asignar comportamientos especificos. De momento veremos el "createdCallback" que es una
especie de constructor para inicializar un custom element en el momento de su creacin. Este
mtodo manejador createdCallback se asigna como propiedad dentro del prototipo.
3. Asignar el prototipo creado para este Custom Element cuando estoy registrando el elemento.
Ahora te muestro el cdigo completo, solo la parte de Javascript que es la que ha cambiado, con estas tres
acciones que acabamos de comentar.
prototipo.createdCallback = function() {
console.log("Creado");
};
document.registerElement('dw-holamundo', {
prototype: prototipo
});
Tmate un tiempo para revisar el cdigo y identifica estos tres bloques necesarios para poder definir
nuestro elemento personalizado.
Vers que se define el prototipo, luego se modifica un poco para finalmente registrar ese prototipo con el
nombre del custom element que ests creando.
Vers que se asigna una funcin a prototipo.createdCallback, que es como un evento que puedes usar para
hacer cosas cuando el custom element se acaba de crear. En ese momento se ejecutar el cdigo de la
funcin asignada a prototipo.createdCallback. Existen en el estndar varios eventos de estos para realizar
acciones en distintos momentos del ciclo de vida de los web components. Los veremos ms adelante con
detalle.
Si te extraa la lnea this.textContent = "Hola Mundo!"; solamente est accediendo al elemento concreto
que se est creando y asignando un texto a su propiedad "textContent", con lo que conseguiremos escribir
algo dentro del contenido del Custom Element que se est definiendo.
Para completar y ampliar estas explicaciones te recomendamos ver el siguiente vdeo en el que mostramos
cmo se crean Web Components con Javascript nativo, es decir, sin usar ninguna librera ms all de las que
nos ofrece el estndar de Javascript.
http://desarrolloweb.com/manuales/web-components.html Pgina 12 de 40
Manual de Web Components
En este artculo vamos a ver un sencillo ejemplo que nos permita explorar otra de las prestaciones de los
Web Components. Se basa simplemente en la posibilidad de crear unos componentes en base a otros. Para
ello usaremos las tcnicas de creacin de Custom Elements ya relatadas en el artculo anterior, agregando
nuevo conocimiento prctico.
Es algo parecido a lo que conocemos como herencia en la Programacin Orientada a Objetos, que nos
permite extender las clases apoyndonos en el cdigo de otras clases padre. En el mundo de los elementos
de una web, nos permitir construir nuevos elementos que son especializaciones de elementos que ya
existen anteriormente.
Creemos que el concepto de extensin se debe entender, pero queremos insistir en ello porque es una de las
principales filosofas de trabajo que nos traen los Web Components. Bsicamente, este estndar se ha
creado de manera que permita que los desarrolladores extiendan el HTML, creando aquellos nuevos
elementos esenciales para realizar su tarea.
Esa capacidad de extensin no solo se da con elementos que existan actualmente en el HTML, sino tambin
con otros custom elements. Es algo que vemos continuamente en todos los mbitos.
En un coche tenemos varios elementos, ruedas, motor, suspensin y stos a su vez estn formados de otros
elementos: por ejemplo el motor a base de un cilindros, pistones, bielas, cigueal, etc. En el mundo del
lenguaje de las personas tenemos las letras y stas forman palabras y las palabras forman frases, etc.
En el mundo de la web podemos tener sistemas compuestos de varios elementos, como un cuadro de
http://desarrolloweb.com/manuales/web-components.html Pgina 13 de 40
Manual de Web Components
bsqueda, que est hecho de un botn y un campo de texto. Para construir una web podr usar botones y
campos de texto, pero si lo que quiero hacer es un campo de bsqueda, usar directamente el componente
de bsqueda. Este componente funciona exactamente igual que si fuera un elemento suelto, es decir, tiene
un nuevo tag (etiqueta) que usar para insertarlo en una pgina. Por tanto, su complejidad y los
componentes internos que necesite para representarse, quedarn encapsulados y protegidos del exterior.
Adicionalmente a crear unos componentes en base a la reunin de otros componentes, tambin podemos
extender componentes ya creados, para dotarles de un comportamiento diferente de los componentes
padre. Sobre este punto vamos a crear un ejemplo.
En el momento en el que nos encontramos todava es un poco pronto para hacer un ejemplo complejo, con
el que podamos representar la capacidad de los Web Components, de asociarse unos con otros para crear
elementos sofisticados. Para hacer todo esto necesitamos hablar antes de otras especificaciones de las 4
disponibles en este estndar. As que nos vamos a conformar por ahora de hacer un elemento que extienda
a otro.
Crearemos un tipo de botn nuevo, que especializa los botones que existen en el lenguaje HTML comn.
Nuestro botn se llama "botonholamundo". No hemos sido demasiado originales. Su comportamiento es
tan bsico como representarse con un texto ya definido (escrito dentro del botn) "Hola Mundo!".
Usando el botn: Para empezar vamos a ver cmo usaramos este custom element, porque difiere un poco
del ejemplo del artculo anterior.
<button is="dw-botonholamundo"></button>
Como puedes ver, ahora no estoy creando una nueva etiqueta personalizada, sino una especializacin de una
etiqueta ya existente.
La etiqueta sobre la que he partido como base es BUTTON y le hemos colocado el atributo is="dw-
botonholamundo" para indicar que no es un botn normal, sino uno que lo extiende y especializa.
Creando el custom element: Ahora vamos a ver cmo creamos el Javascript para generar ese elemento
especializado. Realmente cambian pocas cosas a lo que ya conoces de los custom elements.
Para comenzar, al crear el prototipo no vamos a partir del prototipo genrico de elemento HTML, sino del
prototipo de un elemento HTML botn: HTMLButtonElement.prototype.
Ahora asignamos un pequeo comportamiento a este botn, que especializa el botn genrico del HTML.
Realmente solo le estamos cambiando el texto.
prototipo.createdCallback = function() {
http://desarrolloweb.com/manuales/web-components.html Pgina 14 de 40
Manual de Web Components
};
A la hora de registrar el componente hay otro detalle fundamental para crear estos elementos que extienden
otros y es el uso del atributo "extends" al que le hemos colocado el valor del elemento que est extendiendo:
"button".
document.registerElement('dw-botonholamundo', {
prototype: prototipo,
extends: 'button'
});
Con eso es todo! Ya tenemos nuestro "dw-botonholamundo" listo, un botn que especializa y extiende los
botones bsicos que existen en el HTML tradicional.
Esperamos que te haya gustado, prueba a extender otros elementos y hacer tus propios experimentos.
Nosotros para seguir avanzando vamos a aprender en el siguiente artculo otra de las especificaciones de los
Web Components como es el sistema de templates.
Estamos revisando poco a poco los distintos elementos de los Web Components en Javascript, el estndar
de la W3C para el desarrollo del lado del cliente. En pasados artculos ya presentamos los Web Components
y adems vimos cmo se desarrollan Custom Elements.
Ahora le toca el turno al estndar Template, que nos permite crear plantillas que podemos completar con
datos y presentar luego en el contenido de la pgina mediante Javascript. Es una novedad muy importante,
ya disponible en casi todos los navegadores, por lo que deberamos tenerlo presente para desarrollar con
Javascript. En este artculo explicaremos en qu consiste y veremos ejemplos para entender su
funcionamiento, siempre con Vanilla JS (Javascript nativo).
Los sistemas de templates son uno de los componentes de aplicaciones web que nos facilitan el
mantenimiento del cdigo. Es una herramienta general que encontramos en diferentes lenguajes y es bsica
http://desarrolloweb.com/manuales/web-components.html Pgina 15 de 40
Manual de Web Components
En Javascript hasta el momento no contbamos con ningn sistema para hacer templating, por lo que
tenamos que usar alguna librera de terceros, como podra ser Handlebars JS. Afortunadamente para los
desarrolladores la W3C ha sido consciente de esta necesidad en los estndares abiertos y ha creado un
sistema de templates que los navegadores son capaces de interpretar de manera nativa.
Como veremos a continuacin, para utilizar sistema de templates requerimos usar dos componentes
principales. Por un lado tendremos un HTML con el conjunto de elementos que contiene nuestra plantilla y
por otro lado necesitaremos de un poco de Javascript para volcar datos dentro y presentarlos junto con el
contenido de la pgina.
Etiqueta template
La parte de HTML para implementar el sistema de plantillas de los Web Components se escribe mediante la
etiqueta TEMPLATE.
La etiqueta TEMPLATE es bastante especial, puesto que es la nica etiqueta de contenido que no tiene una
representacin directa en el renderizado de la pgina. Dicho de otra manera, el navegador al leer una
etiqueta TEMPLATE no la inserta en el contenido visible de la pgina, sino que la interpreta y la deja
simplemente en memoria para que luego mediante Javascript se pueda utilizar. Por tanto, cuando en
navegador encuentra un template no hace nada con l, aparte de leerlo, esperando que se use ms adelante
de alguna manera.
La forma de un template en HTML es como cualquier otro cdigo HTML, sin nada en particular, aparte de
estar englobada entre las etiquetas de apertura y cierre de la plantilla.
<template>
<p>Esto es un template!!</p>
</template>
Como hemos mencionado, para usar un template aparecido entre el HTML de la pgina, necesitamos un
http://desarrolloweb.com/manuales/web-components.html Pgina 16 de 40
Manual de Web Components
poco de Javascript.
Esos tres pasos los vamos a ver representados a continuacin en el siguiente cdigo.
document.body.appendChild(clone);
Como ves, un template lo podemos acceder a travs de un selector. Puedes usar document.querySelector() o
incluso algo como document.getElementById(), si es que le pusiste un identificador al template.
Como vers tambin, los templates tienen un atributo "content" que contiene el HTML de dentro de la
etiqueta TEMPLATE.
El paso de realizar un clon es bsicamente porque la idea de un template es que lo puedas insertar repetidas
veces. Por ejemplo, podras tener una lista de contactos y cada uno de esos contactos podra tener un
template para representarse (con el mismo template puedes representar todos los contactos, simplemente
cargando en la plantilla datos distintos). Si tu lista tiene 20 contactos, ese template de un contacto lo
repetirs 20 veces, cargando datos diferentes dentro de l, o sea, se realizarn 20 clones del template que se
inyectarn en la pgina posteriormente. Luego veremos un ejemplo de template que contiene una repeticin
para mostrar diferentes elementos en una lista.
Ahora podemos ver cmo sera una pgina elemental que est usando el template system nativo de
Javascript.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Template simple</title>
</head>
<body>
<h1>Template simple</h1>
<template id="mitemplate">
<p>Esto es un template!!</p>
</template>
http://desarrolloweb.com/manuales/web-components.html Pgina 17 de 40
Manual de Web Components
<script>
document.body.appendChild(clone);
</script>
</body>
</html>
Este cdigo es realmente poco til por dos motivos. Primero porque generalmente vas a usar el sistema de
templating junto con otros estndares de los Web Components. Pero segundo porque si queras presentar
un texto directamente en la pgina podras haberlo colocado tal cual en el cuerpo, en vez de accionar el
sistema de plantillas y volcar ese contenido con Javascript. Paralelamente, como hemos dicho, es muy
habitual contar con algn tipo de repeticin que nos permita iterar y repetir varias veces el template en el
cuerpo de la pgina.
Otra cosa que veremos en el ejemplo a continuacin es que habitualmente dentro de un template podrs
encontrar no solo cdigo HTML, sino tambin cdigo CSS que afectar a los elementos de este template.
Ahora veremos un ejemplo ms completo de uso de templates, en el que ya tenemos un bucle que recorre
un array para repetir un template determinadas veces
En nuestro ejemplo vamos a hacer un listado de ciudades del mundo, con un encabezamiento que rotule el
ttulo de este template. Antes de comenzar este cdigo vamos a aclarar dos puntos.
Estilos CSS son vlidos en un template: Aparte de cdigo HTML podrs incluir tambin cdigo CSS en
un template. Este cdigo lo colocas como siempre, con la etiqueta STYLE. La novedad es que estos estilos
solo afectan al HTML del template, es decir, no salen para afuera y por tanto no afectan a otros elementos
del cuerpo de la pgina. Este punto es muy interesante y a la vez muy til porque permite que coloquemos
estilos a etiquetas sin preocuparnos que stos puedan trastocar el aspecto del resto de la pgina.
Unos templates contienen a otros: Cuando tienes un template ms elaborado, puede que te encuentres en
la necesidad de anidar templates. Por ejemplo en nuestro caso, identificamos dos bloques fundamentales:
Entendidos los puntos anteriores, sers capaz de interpretar bien este cdigo.
<template id="templatesimple">
<style>
h1{
color: red;
p{
background-color: #ddd;
http://desarrolloweb.com/manuales/web-components.html Pgina 18 de 40
Manual de Web Components
</style>
<template id="templateciudades">
<p></p>
</template>
</template>
var p = template.querySelector("#templateciudades").content.querySelector("p");
ciudades.forEach(function(ciudad){
newP.textContent = ciudad;
template.appendChild(newP);
});
document.body.appendChild(clone);
Como ests observando, en el cdigo se accede a ambos templates de manera independiente. Adems
estamos recorriendo el array y realizando diferentes clones para cada ciudad. Tendremos un clon para todo
el template general y otro clon para cada prrafo donde se va a representar cada ciudad.
Nota: Casi sin lugar a dudas te parecer algo complejo para la relativamente sencilla tarea que se est
realizando. Sin embargo, libreras como Polymer te ayudan a simplificar bastante este cdigo.
Conclusin
Hemos conocido el sistema de templates nativo de Javascript y hemos hecho un par de ejemplos para
aclarar cmo se usa, en un template bsico y en otro que incluye una repeticin.
Ya hemos advertido que el verdadero uso de los templates se da cuando los usas en conjunto con otras
herramientas del estndar de los web components, por ejemplo cuando el template forma parte de un
Custom Element.
Aunque te pueda haber parecido complejo el cdigo Javascript para usar un template tenemos que insistir
en dos puntos:
1. El template que usas dentro de un Custom Element queda encapsulado en el custom element, por
lo que lo puedes programar una vez y usar infinitas veces en uno o varios proyectos. O sea, al final
toda la complejidad se queda en el cdigo que vas a reutilizar sin preocuparte de nada
2. Existen libreras que nos permiten volcar de una manera ms sencilla datos en los templates, que
facilitarn crear templates con variables que se rellenan con propiedades de un objeto. Esa parte no
la incluye el estndar de Javascript as que para hacer un cdigo verdaderamente fcil de mantener se
http://desarrolloweb.com/manuales/web-components.html Pgina 19 de 40
Manual de Web Components
recomendara usar alguna librera adicional como Polymer, por lo menos hasta el da de hoy
En futuros artculos seguiremos usando el sistema de template de Web Components, por lo que podrs ver
nuevos ejemplos en breve.
De todas las especificaciones de los Web Components, el estndar de la W3C para el desarrollo de
componentes modulares y completamente reutilizables, Shadow DOM nos ofrece los mecanismos ms
importantes para que los mdulos sean realmente autnomos e independientes de otros elementos de la
pgina. En sntesis, Shadow DOM permite insertar elementos dentro del DOM de la pgina, pero sin
exponerlos hacia afuera, de modo que no se puedan tocar accidentalmente.
Cuando creamos un custom element a menudo ste necesita generar nuevos elementos, como botones,
campos de texto, iconos, prrafos, que colocar debajo de su jerarqua. Todos esos elementos que cree el
custom element podremos decir que le pertenecen directamente. El custom element dueo de sus
elementos podr, o no, ocultarlos de modo que no se puedan acceder desde fuera. Si se decide ocultar o
encapsular esos elementos se usar el Shadow DOM. En ese caso, los elementos estarn fsicamente en el
DOM de la pgina, dependiendo nicamente del custom element que los ha generado y solo se podrn
manipular por su dueo.
Bsicamente, este DOM oculto a otros elementos de la pgina es el que nos permite aislar los
componentes, produciendo la deseada encapsulacin. El beneficio bsico es que, al usar un custom
element en la pgina, su contenido encapsulado no podr interaccionar con otros elementos de fuera,
evitando daos colaterales: Sobre todo, otros elementos de la pgina no podrn romper el estilo o
comportamiento del custom element que us el Shadow DOM.
http://desarrolloweb.com/manuales/web-components.html Pgina 20 de 40
Manual de Web Components
Nota: Quizs hayas experimentado alguna vez la desagradable situacin que al insertar un plugin jQuery
ste rompe estilos en tu pgina. O el componente no funciona porque otras partes de tu cdigo
interaccionan con l, u otros estilos CSS que tenas declarados de manera global. Todo esto est
solucionado en los Web Components y mucho depende directamente de la especificacin de Shadow
DOM.
Ahora vamos a crear unos ejemplos bsicos en los que usaremos la especificacin de Shadow DOM para
que, mediante Javascript, podamos crear e inyectar nuevos elementos en el DOM de la pgina, pero
posibilitando que estn ocultos.
Nota: Como otras especificaciones de los Web Components, podemos usar Shadow DOM sin
necesidad de utilizarlo en conjunto con otras especificaciones como la de Custom Elements. Sin
embargo, lo cierto es que cobra especial sentido y utilidad cuando usamos varias de las especificaciones
en conjunto. Por ello, el siguiente ejemplo tiene sobre todo valor didctico, pero no ilustra del todo su
uso ms habitual. Veremos ejemplos que usen el Shadow DOM junto con otras especificaciones ms
adelante, siendo que en este artculo en el ltimo ejemplo mezclaremos la especificacin de Template y
la de Shadow DOM.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Shadow DOM</title>
<style>
p{
color: red;
</style>
</head>
<body>
<div id="elem"></div>
<script>
//cambiamos el contenido de ese elemento, esto ser creado como "shadow DOM"
</script>
</body>
</html>
http://desarrolloweb.com/manuales/web-components.html Pgina 21 de 40
Manual de Web Components
Para entender el ejemplo hemos colocado varios comentarios. No obstante, lo explicamos de nuevo.
Primero tenemos un elemento de la pgina al que le hemos colocado un identificador, solamente para luego
poder referirnos a l: id="elem".
Ms tarde, cuando ya hemos decidido que queremos usar Shadow DOM, tenemos que producir una raz
donde se va a insertar todo elemento que vaya a estar encapsulado. A esa raz se la conoce como "Shadow
Root" y se genera con la siguiente instruccin:
Por ltimo tenemos que aadir nuevos elementos dentro del Shadow Root y eso lo podemos hacer
mediante varios mecanismos. Un ejemplo sera editar su propiedad innerHTML.
Ese prrafo no se podr tocar desde fuera. Por eso, si te fijas, en la cabecera tenamos un estilo que aplicara
a todos los prrafos de la pgina y, sin embargo, a la hora de la verdad, no est afectando al prrafo que
hemos colocado dentro del Shadow Root.
Nota: Como ves en este ejemplo, insistimos nuevamente, no es necesario incluir ningn tipo de librera
adicional para que el navegador entienda el Shadow DOM. Sin embargo, de momento esto solo
funcionar en Chrome y Opera que son los que ms se han apresurado a cumplir el estndar. Por
supuesto, si usas el correspondiente polyfill podrs ver el ejemplo funcionando tambin en otros
navegadores. Sobre el Polyfill hablaremos tambin en detalle en artculos futuros, aunque tambin
tenemos unas notas interesantes que aportar ms tarde.
Obviamente, en ocasiones conviene poder saltarse la regla y aplicar estilos a elementos que estn dentro de
shadow DOM. Para ello tenemos un selector llamado ::shadow. En realidad es un pseudo elemento que se
usa anteponiendo al selector que queramos aplicar dentro de un nodo Shadow Root.
Para que el prrafo anterior estuviera afectado por el CSS tendramos que usar ::shadow de la siguiente
manera.
<style>
::shadow p{
color: red;
http://desarrolloweb.com/manuales/web-components.html Pgina 22 de 40
Manual de Web Components
</style>
Es una funcionalidad til, aunque debes tener en cuenta que el pseudo elemento ::shadow se ha marcado
como "depretated" (va a estar obsoleto y por tanto no se aplicar soporte en navegadores en adelante). No
obstante, aunque este pseudoelemento sirva para saltarse el encapsulamiento entendemos que resulta
bastante interesante, por lo que esperaramos que se permita el uso de alguna alternativa similar para poder
cubrir esta previsible necesidad.
Quizs la parte que resulta ms complicado de simular meditante un polyfill, dentro de lo que respecta a los
web components, es la de Shadow DOM. Por ello, el soporte a esta especificacin de la W3C en los
"polyfilled browsers" no es completo.
Por tanto, aunque el navegador muestre en la pgina aquellos elementos que se hayan colocado dentro de
un Shadow Root, realmente no existir esa mencionada encapsulacin y se podrn tocar desde fuera, o
alterar su aspecto con CSS definidos de manera global.
Ese motivo tambin hace que libreras como Polymer toquen el Shadow DOM, al menos por ahora, de una
manera especial, no aportando todas las ventajas que tendra a priori en los navegadores que no lo soportan
de manera nativa. Esto se hace para evitar afectar muy negativamente al rendimiento de las aplicaciones con
Web Components y para que el comportamiento sea diferente en navegadores que lo implementan de
manera nativa y los que no.
Antes de acabar, vamos a ver cmo alterar un poco nuestro ejemplo para que podamos usar un template,
cuyo contenido se va a insertar como Shadow DOM. Recuerda que vimos templates de Web Components
en un artculo anterior.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Shadow DOM</title>
</head>
<body>
<div id="elem"></div>
<template>
<p>Esto es un template!!</p>
</template>
<script>
//accedo al template
//accedo a un elemento
http://desarrolloweb.com/manuales/web-components.html Pgina 23 de 40
Manual de Web Components
shadow.appendChild(clone);
</script>
</body>
</html>
La diferencia es bien poca, simplemente tengo que acceder al template y clonar aquella parte que quiero usar
dentro del Sadow DOM de otro elemento.
Luego ese clon del template es el que aado al Shadow Root con el mtodo appendChild().
shadow.appendChild(clone);
En artculos anteriores hemos relatado qu hay de nuevo con los Web Components y cmo van a
revolucionar el desarrollo para la web. Es un nuevo estndar que nos trae cuatro especificaciones para poder
construir, en resumen, nuevos elementos o componentes que nos ayudarn a extender el HTML a todos los
niveles.
De entre todas las especificaciones ahora vamos a explicar la relacionada con los import, que es la ltima
que nos quedaba por ver en el manual de los Web Components. Se trata de una especificacin bastante
sencilla que realmente usaremos poco a nivel de Javascript y ms a nivel de HTML. Pero mejor vamos
directamente con las explicaciones.
http://desarrolloweb.com/manuales/web-components.html Pgina 24 de 40
Manual de Web Components
Cuando desarrollamos tradicionalmente del lado del cliente nos valemos del lenguaje HTML para definir el
contenido, del CSS para definir el aspecto y del Javascript para la funcionalidad o programacin en general.
Estos tres lenguajes se pueden escribir en el mismo documento HTML, pero generalmente su cdigo se
coloca en archivos independientes por diversos motivos.
Cuando quieres extender el HTML, por medio de lo que tradicionalmente se conoce como plugins
(recuerda los plugin de jQuery), generalmente tienes que incluir diversos cdigos por separado. Por una
parte necesitaremos colocar un poco de HTML que es donde se va a embutir la funcionalidad del plugin,
tendrs un script Javascript que colocars en tu archivo .js del sitio o en el archivo plugins.js junto con otros
plugins que quieras usar y por ltimo un poco de CSS que generalmente colocars en el archivo de estilos
globales de tu sitio.
No existe una regla que sea totalmente obligatoria sobre cmo situar esos pedazos de cdigo en tu pgina y
a veces genera un poco de confusin, pero sobre todo dificulta la distribucin de plugins y su
http://desarrolloweb.com/manuales/web-components.html Pgina 25 de 40
Manual de Web Components
mantenimiento. Los creadores de los plugins seguramente les gustara poder decirte "mira, coloca este
archivo aqu y no te preocupes por nada ms". Pero no pueden porque esas tres porciones de cdigo
(HTML + CSS + JS) que tendrs que situar en tu proyecto en lugares diferentes dependiendo de la
arquitectura de tu pgina.
Para ese caso concreto es el que se crea la nueva especificacin de los "import". Se trata bsicamente de
incluir todo lo necesario para distribuir un componente en un nico archivo .html. Aunque, a pesar de la
extensin no tendr solo el cdigo HTML para funcionar, sino tambin sus estilos y su Javascript para darle
vida.
En resumen, cuando quieras usar un Web Component en una pgina web no vas a tener que estar
incluyendo los distintos cdigos de los distintos lenguajes por separado, simplemente colocars un nico
import a tu componente y ya lo tendrs listo para usar. interesante, no?
Nota: Hasta el momento no existen en HTML ninguna etiqueta que nos permita traer un cdigo
HTML que tengamos en otro documento. Esta tarea es algo normal en el da a da del desarrollo y
seguro que la has realizado en alguna ocasin si programas en lenguajes como PHP por medio de las
sentencias include o require. Todos los lenguajes tienen herramientas para traerse y usar cdigo que hay
en otros ficheros, la pregunta mejor sera Cmo es que HTML no la tena?
En el pasado se trat de hacer uso de algn tipo de tcnica que nos permitiera acceso a pedazos de
HTML para mantener en un nico lugar partes de la pgina que se repetan innmeras veces a lo largo
de todo un sitio web, como por ejemplo la cabecera o el pie. Ninguna de las alternativas se lleg a
establecer por diversos motivos y nos veamos obligados a implementar esa funcionalidad del lado del
servidor.
Los import de Web Components podran suplir esta necesidad, pero la verdad es que no estn pensados
solo para ello. Realmente, como hemos dicho, estn pensados para distribuir componentes en un nico
archivo que contiene todo el cdigo necesario para que funcionen.
Como ya sabes lo que es un Custom Element, te aclarar saber que con un Import incluyes todo el cdigo
fuente necesario para que el navegador conozca uno de estos elementos personalizados. El import lo haces
en la cabecera de la pgina y luego a lo largo de todo el cuerpo podrs usar la etiqueta que implementa el
Custom Element todas las veces que necesites.
Para realizar un import en un documento HTML se usa la etiqueta LINK que ya existe desde hace tiempo
en el lenguaje. Anteriormente LINK te serva nicamente para acceder a una hoja de estilos externa, en un
archivo CSS que generalmente enlazas con todas las pginas de tu sitio. Ahora los LINK tendrn la
posibilidad de definir su atributo rel="import" y con ello indicas que ests usando esta especificacin de
Web Components.
Esta etiqueta ahora permite enlazar con un archivo HTML que, como decimos, puede tener cdigo no solo
http://desarrolloweb.com/manuales/web-components.html Pgina 26 de 40
Manual de Web Components
Ahora bien, hacer el import no implica que vayas a mostrar un HTML en un lugar concreto de la pgina!!
No veas el import como si fuera un "include" de un HTML, sino como un enlace a un cdigo que
realmente no se va a mostrar donde est situado tu import, sino donde t lo necesites. Como consecuencia,
los import se suelen situar en el HEAD de la pgina. All podremos colocar todos los import que
necesitemos en nuestro documento. Luego usaremos los import donde se necesiten, atendiendo a estas
reglas fundamentales:
El HTML de un import no se va a volcar en el sitio donde has definido tu etiqueta LINK. Osea, si
colocas un import a un archivo que solo contiene cdigo HTML ser como si no colocases nada,
ese HTML no aparecer por ningn sitio, tendrs que volcarlo ms tarde con Javascript para que
aparezca donde quieras.
El CSS que haya en un archivo que importes se incluir como CSS de la pgina, sumndose al CSS
global con la regla de la cascada. Ahora bien, si colocas CSS lo tendrs que incluir con las
correspondientes etiquetas STYLE y barra STYLE.
El Javascript que haya en un import se ejecutar directamente. Pero para colocar un script lo tendrs
que hacer dentro de las etiquetas SCRIPT.
Los import que te traes con la etiqueta LINK rel="import" se acceden mediante HTTP, que es el protocolo
de transferencia de las pginas web. Esto es importante porque un import solo funcionar si tu pgina se
accede a travs de http://. En definitiva, para que funcionen tendrs que acceder al documento que realiza
el import a travs de un servidor web.
Para los que ya conocen Javascript de antes, es algo parecido a lo que pasa con las solicitudes Ajax.
Realmente es que un import es como si fuera una solicitud Ajax para acceder a otro documento, que el
navegador solicita a un servidor web a travs del protocolo HTTP.
Contar con un servidor es sencillo y te vale cualquier servidor que puedas conseguir. En ltimo trmino, si
no sabes cmo proveerte de un servidor web, te vale subir los archivos a un espacio de hosting web. Pero si
trabajas desde hace tiempo en el mundo web sabrs cmo conseguir un servidor en local, que es lo ms
adecuado para la etapa de desarrollo. En DesarrolloWeb.com tienes mucha informacin para conseguir
esto.
Terminaremos este artculo con una pequea prctica sobre Javascript para acceder a un import. El objetivo
es no quedarnos solo en el conocimiento terico, pero hay que remarcar que esta prctica no es realmente
habitual en el da a da del desarrollo Web Components. Lo que vamos a hacer es acceder a un cdigo
HTML que est dentro de un import para presentarlo en un lugar de la pgina, pero recuerda que lo normal
es que el import te sirva para incluir cdigo en diferentes lenguajes que implementa un Custom Element.
Archivo que vamos a importar: archivo-importar.html Tenemos primero el archivo que vamos a
importar, que contiene cdigo HTML simplemente (insistimos que sto no es lo ms normal).
http://desarrolloweb.com/manuales/web-components.html Pgina 27 de 40
Manual de Web Components
Archivo que realiza la importacin: Ahora, desde cualquier archivo donde vayamos a importar un
elemento, usamos en el HEAD la etiqueta LINK con rel="import" y luego en el href la ruta del archivo a
importar.
Recuerda que por hacer el import, ese contenido HTML a importar no se mostrar dentro de la pgina.
Luego en el cdigo veremos el script que nos permitira acceder al contenido del import para presentarlo en
un lugar de la pgina.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>HTML Imports</title>
</head>
<body>
<script>
document.body.appendChild(elementoDentroImport);
</script>
</body>
</html>
Como decimos, este cdigo Javascript no deja de ser anecdtico. Se puede hacer esto que ves y el ejemplo
funciona, pero no es lo ms habitual. El cdigo est comentado para que lo puedas analizar y entender
como facilidad. No lo vamos a comentar ms porque no es lo que realmente se espera de los import como
hemos remarcado hasta la saciedad.
En el siguiente artculo realizaremos un ejemplo de import a un Custom Element que habr en un archivo
.html que contendr tanto HTML como CSS como Javascript. En el prximo ejemplo, por tanto, s podrs
ver cul es el uso que se ha pensado para dar a esta especificacin de Web Components.
http://desarrolloweb.com/manuales/web-components.html Pgina 28 de 40
Manual de Web Components
Los Web Components son una tecnologa incipiente que va a cambiar el modo con el que se desarrollan las
aplicaciones para navegadores. Ya hemos empezado a hablar sobre ellos en otras ocasiones en el Manual de
Web Components, as que nos centraremos ahora en un tema especfico y clave para los desarrolladores,
como es su ciclo de vida.
El ciclo de vida es parte de la especificacin de los Web Components y bsicamente incluye diversos
estados que pueden tener los Custom Elements a lo largo de su existencia. Desde la creacin de un
componente, su insercin dentro del documento web hasta su retirada, por poner varios ejemplos. Por
medio de estos estados, por los que pasa cualquier componente, podemos personalizar su comportamiento
en circunstancias muy concretas.
Bsicamente el ciclo de vida est ah para servir de utilidad a los desarrolladores de componentes, ya que
permiten escribir cdigo Javascript que ser ejecutado cuando el componente va pasando por sus diferentes
estados. Esta operacin se realiza por medio de lo que se conoce como funciones "callback": funciones que
son declaradas pero que no se ejecutan hasta que pasan ciertas cosas.
Para comenzar vamos a describir los estados de un componente que definen su ciclo de vida:
Created: Ocurre cuando el elemento se crea, pero ojo, no tiene que ver con que el elemento se
muestre. Es como su instanciacin en memoria de Javascript. Cada elemento de un tipo de custom
element generado, lanza el mtodo created.
Attached: Ocurre cuando un elemento que haba en la memoria de Javascript se inyecta dentro de
un documento, o sea, pasa a formar parte del DOM de la pgina.
Detached: Ocurre cuando un elemento se quita del DOM, se retira del documento y por tanto
desaparece de la pgina.
Atribute Changed: Ocurre cuando uno de sus atributos cambia de valor.
Nota: Estos son los estados del ciclo de vida de los custom elements en Javascript estndar, aunque
algunas libreras basadas en Web Components incorporan otros adicionales.
http://desarrolloweb.com/manuales/web-components.html Pgina 29 de 40
Manual de Web Components
Puedes ver todos esos estados son como si fueran eventos que ocurren durante la vida de un componente.
Como a los eventos, seremos capaces de asociar funciones manejadoras, que se encargan de producir
comportamientos personalizados para cada suceso. En este caso llamamos a esas funciones con el trmino
"calback", usado en el estndar como ahora podrs ver.
Ahora veremos el cdigo del registro de un componente en el que usaremos los diversos mtodos callback
del ciclo de vida. Pero para entenderlo te sugerimos la lectura del artculo del estndar de los Custom
Elements, en el que se explicaron ya muchas cosas que aqu vamos a dar por sabidas.
// Defino una funcin callback para el instante del ciclo de vida "created"
elemento.createdCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "attached"
elemento.attachedCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "detached
elemento.detachedCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "attributeCanged"
};
// Este es el cdigo para registrar el componente, en el que indicamos su prototipo que acabamos de definir
document.registerElement('ciclo-de-vida', {
prototype: elemento
});
Solo con que uses un elemento, colocando la etiqueta HTML 'ciclo-de-vida' ste se generara y se adjuntara
al DOM, con lo que ya se pondrn en marcha los mtodos del ciclo de vida, con sus correspondientes
console.log().
<ciclo-de-vida></ciclo-de-vida>
http://desarrolloweb.com/manuales/web-components.html Pgina 30 de 40
Manual de Web Components
Nota: Obviamente, para que ese elemento funcione debe conocerse previamente el elemento, por lo
que el script para registrarlo visto en el punto anterior debera aparecer antes en el cdigo HTML. (Mira
al final el cdigo completo del ejercicio).
Quizs con nuestro ejemplo te sorprenda que no observars cambios en la pgina, porque el elemento del
ejemplo no tiene template, pero s deberas ver los mensajes si abres la consola Javascript.
se ha creado un elemento
se ha aadido un elemento al DOM
Para ver otros mtodos del ciclo de vida necesitas el cdigo de algunas funciones Javascript de
manipulacin del DOM. Para ello hemos colocado tres botones que invocan tres manipulaciones diferentes
sobre el DOM, que provocarn nuevos mensajes a la consola de Javascript.
Esos eran los tres botones, a los que les colocamos tres manejadores de eventos para realizar cosas con
elementos:
document.getElementById('cambiaAtr').addEventListener('click', function() {
document.querySelector('ciclo-de-vida').setAttribute('data-test', 'test-value');
});
document.getElementById('quitarDOM').addEventListener('click', function() {
document.body.removeChild(document.querySelector('ciclo-de-vida'));
});
document.getElementById('crearElemento').addEventListener('click', function() {
document.createElement('ciclo-de-vida');
});
Cdigo completo
Eso es todo lo que necesitas para practicar con los mecanismos del ciclo de vida de los custom elements.
Ahora para aclarar posibles dudas dejamos el cdigo completo del ejercicio.
Nota: Recuerda que, a pesar que esto sea todo Javascript nativo, solo funcionar para los navegadores
que ya implementan el estndar de los Web Components. Para navegadores que an no lo tienen
disponible simplemente habra que usar el correspondiente polyfill, del que ya hemos hablado
anteriormente en este manual.
<!DOCTYPE html>
http://desarrolloweb.com/manuales/web-components.html Pgina 31 de 40
Manual de Web Components
<html lang="en">
<head>
<meta charset="UTF-8">
<script>
(function() {
// Defino una funcin callback para el instante del ciclo de vida "created"
elemento.createdCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "attached"
elemento.attachedCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "detached
elemento.detachedCallback = function() {
};
// Defino una funcin callback para el instante del ciclo de vida "attributeCanged"
};
// Este es el cdigo para registrar el componente, en el que indicamos su prototipo que acabamos de definir
document.registerElement('ciclo-de-vida', {
prototype: elemento
});
}());
</script>
</head>
<body>
<ciclo-de-vida></ciclo-de-vida>
<script>
window.onload = function() {
document.getElementById('cambiaAtr').addEventListener('click', function() {
document.querySelector('ciclo-de-vida').setAttribute('data-test', 'test-value');
});
document.getElementById('quitarDOM').addEventListener('click', function() {
document.body.removeChild(document.querySelector('ciclo-de-vida'));
});
document.getElementById('crearElemento').addEventListener('click', function() {
document.createElement('ciclo-de-vida');
});
</script>
http://desarrolloweb.com/manuales/web-components.html Pgina 32 de 40
Manual de Web Components
</body>
</html>
http://desarrolloweb.com/manuales/web-components.html Pgina 33 de 40
Manual de Web Components
En los siguientes artculos nos dedicaremos a mostrar ejemplos que nos permitan entender cmo usar Web
Components, con sus diversas especificaciones en conjunto, para el desarrollo web. De este modo
pretendemos ofrecer ejemplos ilustrativos sobre las posibilidades de este nuevo estndar.
Este artculo va a presentar un par de ejemplos sencillos de Web Components, muy elementales, que nos
permitan asimilar un poco ms las nuevas API para trabajo con este nuevo estndar desde Javascript.
En el artculo anterior presentamos la especificacin import, pero lo que vimos es algo casi anecdtico,
porque realmente un import no sirve para traerse el contenido HTML de un archivo externo, sino ms bien
para importar el cdigo de nuevos componentes que podras usar en cualquier documento HTML.
En esta ocasin mostraremos un uso ms razonable de import, el de traerse el cdigo de dos custom
element creados para la ocasin. En resumen, usaremos las especificaciones:
Componente dw-date
Este componente simplemente muestra la fecha y hora del instante actual en la pgina. Se usa as:
<dw-date></dw-date>
Como comportamiento del componente, al donde aparezca, se sustituir por la fecha actual. Algo as como:
http://desarrolloweb.com/manuales/web-components.html Pgina 34 de 40
Manual de Web Components
El cdigo del componente tiene esta forma: (con los comentarios y las explicaciones anteriores del Manual
de Web Components estamos seguros que podrs entenderlo)
<script>
prototipo.createdCallback = function() {
};
document.registerElement('dw-date', {
prototype: prototipo
});
</script>
Componente romper-cadena
Ahora vamos a ver un segundo ejemplo de Web Component sencillo, pero esta vez un poco ms til. Este
elemento permite romper un texto en una longitud en caracteres dada, pero sin romper las palabras.
El texto de la cadena original ser el propio texto que haya en el elemento y adems tendr un atributo
llamado "len" donde se marcar esa longitud mxima de caracteres para el recorte. Si no es posible romper
en esa longitud, porque se rompa una palabra, se entrega la cadena hasta el espacio en blanco anterior.
<script>
(function() {
return cadena;
http://desarrolloweb.com/manuales/web-components.html Pgina 35 de 40
Manual de Web Components
prototipo.createdCallback = function() {
//lo recorto
this.textContent = cadena;
};
document.registerElement('romper-cadena', {
prototype: prototipo
});
})();
</script>
Nota: en este elemento hemos realizado la envoltura del cdigo mediante una funcin, ya que tiene sentido
para encapsular la funcin Javascript usada "recortar()", as evitamos que su nombre colisione con el de otra
funcin creada por aquella persona que use este componente. Ese patron se llama IIFE o closure.
Ahora llega la parte de los import. Si quieres usar esos componentes en una pgina los tendrs que importar.
El sistema es bien simple, gracias a la etiqueta IMPORT. Podrs ver el demo completo de estas dos
etiquetas en este cdigo:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Importar un webcomponent</title>
</head>
<body>
<dw-date></dw-date>
<br>
<br>
</body>
</html>
Como puedes comprobar, despus de los correspondientes import, somos capaces de usar las nuevas
etiquetas creadas al registrar los componentes.
Recuerda que es una tecnologa estndar, por lo que no necesitas una librera adicional Javascript para que
funcione. Sin embargo, si queremos compatibilidad con navegadores que an no implementan este estndar,
http://desarrolloweb.com/manuales/web-components.html Pgina 36 de 40
Manual de Web Components
<script src="https://cdnjs.cloudflare.com/ajax/libs/webcomponentsjs/0.7.21/webcomponents-lite.min.js"></script>
Esperamos que estos ejemplos te sirvan para seguir avanzando en el aprendizaje de Web Components,
ilustrando con nuevos ejemplos la prctica con esta tecnologa. Es interesante ver las cosas que se pueden
conseguir con los custom elements ms sencillos y cmo somos capaces de usarlos en una pgina web
cualquiera.
En el Manual de Web Components hemos abordado diversas especificaciones del estndar que nos han
mostrado por separado las posibilidades de este nuevo modelo de desarrollo Javascript. Pero la verdad es
que estas tecnologas cobran ms sentido si se usan en conjunto, as que vamos a juntarlo todo para
experimentar el estndar de la mejor manera.
Usaremos nicamente Javascript estndar, sin apoyarnos en ninguna librera adicional, lo que se conoce
como VanillaJS. Estos ejemplos funcionarn en cualquier navegador, siempre que incluyas el Polyfill, sin
embargo, lo mejor es que los veas en Chrome que es cliente web que ms camino andado tiene para
implementar la tecnologa.
Nuestro ejercicio consiste en crear un compoente que muestre un mensaje de feedback con un formato ms
atractivo estticamente, que lo que sera un prrafo normal. Algo sencillo para comenzar, pero que nos
permite trabajar con las 4 especificaciones:
Custom Elements
Templates
http://desarrolloweb.com/manuales/web-components.html Pgina 37 de 40
Manual de Web Components
Shadow DOM
HTML Import
La etiqueta nueva que vamos a crear se llamar feedback-message. Realmente solo presenta un mensaje con
un estilo especial, que podramos haber conseguido con una simple clase de CSS, no obstante como prctica
es interesante.
Comenzamos con el archivo del componente. En un nico archivo reunimos todo el HTML y el Javascript
necesario para crear un elemento personalizado. Despiezamos sus dos partes principales:
El template: donde colocas todo el HTML local que va a tener este componente. Ese template a
menudo estar vaco de contenido y se cargar con Javascript en tiempo de ejecucin. Es nuestro
caso. Vers que el template tienen un nico prrafo y est vaco. El contenido lo sacaremos del
mismo documento HTML, lo que hay dentro de la etiqueta del custom element.
El script: que registrar el componente y le dar su comportamiento especial. En ese script nos
encargamos de hacer diversas tareas laboriosas y de cdigo un tanto largo. Pero en realidad son
pequeas y simples acciones que estn comentadas perfectamente.
Nota: Para entender bien las diferentes acciones deberas leer los artculos sobre las distintas
especificaciones de Web Components que hemos enlazado antes. Si te parece demasiado complicado
piensa que cuando usas una librera este cdigo se simplifica bastante, llegando a ser mucho ms
entendible y sobre todo de un mantenimiento sensiblemente ms cmodo.
<template>
<style>
p{
background-color: azure;
padding: 10px;
</style>
<p></p>
</template>
<script>
prototipo.createdCallback = function() {
http://desarrolloweb.com/manuales/web-components.html Pgina 38 de 40
Manual de Web Components
this.innerHTML = "";
// clono el template
parrafo.innerHTML = elementContent;
if(this.hasAttribute("color")){
parrafo.style.color = color;
this.createShadowRoot().appendChild(clone);
};
document.registerElement('feedback-message', {
prototype: prototipo
});
</script>
1. El import del cdigo del componente, que debers poner en cada pgina que necesite usarlo
2. Colocar la etiqueta nueva que has creado
Adems opcionalmente podras usar el Polyfill de Web Components, que nos permitir usarlo en todos los
navegadores modernos.
<!DOCTYPE html>
<html lang="ee">
<head>
<meta charset="UTF-8">
<script src="../bower_components/webcomponentsjs/webcomponents.js"></script>
</head>
<body>
<p>Debajo de este prrafo aparece el mensaje de Feedback generado con un custom element.</p>
http://desarrolloweb.com/manuales/web-components.html Pgina 39 de 40
Manual de Web Components
</body>
</html>
El import lo colocas generalmente en la cabecera, con el href hacia la ruta donde se encuentra el cdigo del
componente.
Nota: Si tienes muchos import es una prctica habitual crear un import nico y que ste sea el que haga
toda la lista de los muchos import que puedas estar usando.
Otra cosa que encuentras en el HEAD es el Javascript que carga el polyfill de compatibilidad
webcomponents.js.
El uso del componente lo tienes ms abajo, en la etiqueta nueva que hemos creado al registrar el
componente.
Al ejecutarlo deberas ver el mensaje de feedback con un color de fondo azul y el texto de color gris.
Podras cambiar el color del texto simplemente cambiando el valor del atributo "color".
http://desarrolloweb.com/manuales/web-components.html Pgina 40 de 40