Web Components 是浏览器原生支持的可复用自定义元素标准,由 Custom Elements(定义带短横线标签及生命周期)、Shadow DOM(提供样式与 DOM 隔离)和 HTML Templates(惰性加载结构模板)三部分构成,核心价值在于原生性与跨框架解耦。

Web Components 是浏览器原生支持的一套技术标准,用来创建可复用、封装良好的自定义 HTML 元素。它不是某个库或框架,而是由几个底层 API 组成的规范,包括 Custom Elements、Shadow DOM 和 HTML Templates。
Custom Elements:定义自己的 HTML 标签
你可以用 customElements.define() 注册一个全新的 HTML 标签,比如 或 。这个标签有自己独立的结构、样式和行为,且能像原生元素一样使用,支持属性、事件、生命周期钩子(如 connectedCallback)。
名称必须包含短横线(-),例如 user-card,不能是 usercard 可以继承内置元素(如 HTMLButtonElement),实现“增强型按钮” 不依赖框架,但可与 React/Vue 等共存
Shadow DOM:真正的样式与 DOM 隔离
在自定义元素内部,你可以调用 attachShadow({ mode: 'open' }) 创建一个影子根(shadow root)。它会形成一个独立的 DOM 子树,外部 CSS 无法穿透影响其中内容,内部样式也不会泄漏出去。
mode: 'open' 允许 JS 从外部访问 shadow root;'closed' 则完全隐藏 样式作用域天然隔离,避免全局污染,也无需 CSS Modules 或 scoped style 可通过 ::part() 和 ::theme()(部分浏览器支持)对外暴露可定制的样式钩子
HTML Templates:声明式、惰性加载的结构模板
标签用于存放不会被立即渲染的 HTML 片段。它只在 JS 中通过 content.cloneNode(true) 实例化后才真正生效,非常适合做 Web Components 的默认结构。
立即学习“Java免费学习笔记(深入)”;
模板内容不会被解析执行(script 不运行、图片不加载),性能友好 配合 document.querySelector('template').content 可快速注入到 Shadow DOM 中 支持 slot 分发,实现类似 Vue 的 内容投影功能
基本上就这些。Web Components 的核心价值在于“原生”和“解耦”——不依赖构建工具、不绑定特定生态,适合做设计系统、微前端基础组件或跨框架共享 UI。写法略偏底层,但现代浏览器支持已很完善(Chrome/Firefox/Safari/Edge 均支持)。
以上就是Javascript中的Web Components是什么?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1542020.html
微信扫一扫
支付宝扫一扫