0

0

javascript如何实现组件化_Web Components的基本概念是什么

紅蓮之龍

紅蓮之龍

发布时间:2026-01-01 22:52:02

|

313人浏览过

|

来源于php中文网

原创

web components 是浏览器原生支持的组件化标准,由 custom elements、shadow dom 和 html templates 三大技术组成,实现可复用、自治、隔离的 ui 单元;它无需框架即可跨平台运行,支持跨框架使用与 seo,是补足底层能力的原生组件化方案。

javascript如何实现组件化_web components的基本概念是什么

JavaScript 实现组件化,核心是封装可复用、自治、隔离的 UI 单元;Web Components 是浏览器原生支持的一套标准 API,让开发者能创建真正独立的自定义 HTML 元素。

Web Components 的三大基础技术

它不是单一技术,而是由三个规范协同工作的组合:

  • Custom Elements:定义和注册自定义 HTML 标签(如 <my-button></my-button>),支持生命周期回调(connectedCallbackdisconnectedCallback 等)
  • Shadow DOM:为组件提供样式与结构的局部作用域,内部 CSS 不会泄露,外部样式也默认进不去,实现真正的样式隔离
  • HTML Templates<template></template><slot></slot>):声明不立即渲染的 DOM 片段,配合 <slot></slot> 实现内容分发(类似 Vue 的 slot 或 React 的 children)

一个最简 Web Component 示例

以下代码定义了一个带默认文本、可接收属性、有自己样式的按钮组件:

class MyButton extends HTMLElement {
  constructor() {
    super();
    const shadow = this.attachShadow({ mode: 'open' });
    const template = document.createElement('template');
    template.innerHTML = `
      <style>
        button { background: #007bff; color: white; border: none; padding: 8px 16px; }
      </style>
      <button><slot>Click me</slot></button>
    `;
    shadow.appendChild(template.content.cloneNode(true));
  }

  static get observedAttributes() {
    return ['disabled'];
  }

  attributeChangedCallback(name, oldValue, newValue) {
    if (name === 'disabled') {
      this.shadowRoot.querySelector('button').disabled = newValue !== null;
    }
  }
}

customElements.define('my-button', MyButton);

使用时只需:<my-button disabled>Submit</my-button>,它会自动渲染、响应属性变化,且样式不会影响页面其他部分。

火山方舟
火山方舟

火山引擎一站式大模型服务平台,已接入满血版DeepSeek

下载

立即学习Java免费学习笔记(深入)”;

为什么说它是“原生组件化”

不同于 React/Vue 等框架的组件抽象,Web Components 直接运行在浏览器引擎层:

  • 无需框架即可在任何现代浏览器中运行(Chrome 54+、Firefox 63+、Safari 10.1+、Edge 79+)
  • 组件可跨框架使用(React 项目里能直接用 <my-input></my-input>,Vue 项目也能用)
  • 天然支持 HTML 语义、可访问性(a11y)、SEO,因为本质就是扩展的 HTML 元素

实际开发中怎么用更高效

纯原生写法略繁琐,推荐结合工具提升体验:

  • lit(轻量级库)简化模板、响应式属性、更新逻辑,几行代码就能写出高性能组件
  • Storybook 单独开发和测试组件,不依赖主应用上下文
  • 通过 npm 包 + 自定义元素名前缀(如 my-company-button)避免命名冲突,便于团队共享组件库

基本上就这些。不复杂但容易忽略的是:Web Components 不是替代框架,而是补足底层能力——它让组件真正“可移植”,也让框架更专注上层交互逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1020

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

817

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1686

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

395

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1025

2025.04.24

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4144

2024.08.14

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2023.11.24

seo页面描述
seo页面描述

一个好的SEO页面描述应该包含关键词、简明扼要地概括网页的主题和内容、具有吸引力、与网页内容相符,并且是独特的。它不仅可以帮助搜索引擎了解网页的内容,还可以吸引用户点击进入网页。因此,编写一个优秀的SEO页面描述对于网页的排名和点击率都非常重要。

218

2023.08.31

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 39.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号