Get to know MDN better
Esta página ha sido traducida del inglés por la comunidad. Aprende más y únete a la comunidad de MDN Web Docs.
Los Componentes Web son un paquete de diferentes tecnologías que te permiten crear elementos personalizados reutilizables — con su funcionalidad encapsulada apartada del resto del código — y utilizarlos en las aplicaciones web.
Como desarrolladores, sabemos que reutilizar código tanto como sea posible es una buena idea. Esto tradicionalmente no es sencillo para estructuras de marcado personalizadas — piense en el complejo HTML (y sus estilos y scripts asociados) que en ocasiones se han tenido que escribir para renderizar controles de interfaz (UI) personalizados, y ahora usarlos múltiples veces puede crear un caos en la página si no se es cuidadoso.
Los Componentes Web apuntan a resolver dichos problemas — consiste en tres tecnologías principalmente, las que se pueden usar juntas para crear elementos personalizables versátiles que encapsulan la funcionalidad y pueda ser reutilizada donde sea sin miedo a colisiones de código.
La aproximación básica para implementar un componente web, generalmente es la siguiente:
Guía que muestra como usar las características de los elementos personalizados para crear componentes web sencillos, así como revisar las llamadas del ciclo de vida y algunas características más avanzadas.
Utilizando el shadow DOMGuía que trata los fundamentos del shadow DOM, mostrando como adjuntar un shadow DOM a un elemento, añadir el árbol del shadow DOM, añadirle estilos y más.
Usando templates y slotsGuía que muestra como definir una estructura HTML reutilizable utilizando elementos <template> y <slot> elements, y entonces usar esa estructura debto del componente web.
Contiene funcionalidad relacionada a los elementos personalizados, más notablemente el método CustomElementRegistry.define() utilizado para registrar nuevos elementos personalizados para que se puedan usar en el documento
Window.customElementsRetorna una referencia al objeto CustomElementRegistry.
Llamadas del ciclo de vida (Life cycle callbacks)Llamadas de funciones especiales declaradas dentro de la clase de definición de los componentes personalizados, los que afectan su comportamiento:
Pseudo-clases relacionadas específicamente a elementos personalizados:
Pseudo-elementos relacionados especificamente a elementos personalizados:
Representa el nodo raíz de un subárbol de un shadow DOM.
DocumentOrShadowRootUn mixin definiendo características que son disponibles a través de documentos y shadow roots.
Extensiones a ElementExtensiones a la interfaz Element relacionada al shadow DOM:
Adiciones a la interfaz Node relevantes al shadow DOM:
Extensiones a la interfaz Event relacionada al shadow DOM:
Contiene un fragmento de HTML que no es renderizado cuando se carga inicialmente un documento que lo contiene, pero puede ser desplegado en tiempo de ejecución usando JavaScript, principalmente usado como la base de la estructura de los elementos personalizados. La interfaz DOM asociada es HTMLTemplateElement.
<slot>Un espacio termporal dentro de un componente web que se puede llenar con una plantilla de marcado propia, lo que permite crear árboles DOM separados y presentarlos juntos. La interfaz DOM asociada es HTMLSlotElement.
El atributo global HTML slotAsigna un slot en un shadow tree de un shadow DOM shadow tree a un elemento.
SlotableUn mixin implementado tanto por los nodos Element y Text, definiendo características que les permiten convertirse en el contenido de un elemento <slot>. El mixin define un atributo, Slotable.assignedSlot, el cual retorna una referencia al nodo del slot donde esta insertado.
Extensiones a ElementExtensiones a la interfaz Element relacionadas a slots:
Pseudo-elementos especificamente relacionados a slots:
Disparado en una instancia HTMLSlotElement (elemento <slot>) cuando el o los nodos contenidos es ese slot cambia.
Se están construyendo varios ejemplos en nuestro repositorio de GitHub web-components-examples. Se añadirán más con el tiempo.
| HTML # the-template-element |
| DOM # interface-shadowroot |
(Imagen tomada de webcomponents.org)
Para revisar detalladamente el soporte para ciertas características (sobre todo en versiones anteriores o navegadores antiguos), se puede consultar las páginas de referencia listadas anteriormente
This page was last modified on 24 jun 2025 by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.