当前位置: 首页 > news >正文

微前端实战:打造高效、灵活的前端应用架构

文章目录

  • 一、微前端简介
  • 二、微前端的优势
    • 1. 高度模块化
    • 2. 独立部署
    • 3. 易于扩展
    • 4. 技术栈无关
    • 5. 独立升级
  • 三、微前端的原理
  • 四、微前端案例思路
  • 《微前端实战》
    • 编辑推荐
    • 内容简介
    • 作者简介
    • 目录
    • 前言/序言


随着互联网行业的快速发展,前端应用的规模和复杂度也在不断增加。为了应对这种挑战,越来越多的企业和开发者开始探索新的前端架构模式。微前端作为一种新兴的前端架构模式,凭借其高度模块化、独立部署、易于扩展等特点,逐渐成为了业界的热门话题。本文将通过一个实际案例,详细介绍微前端的概念、原理以及在实战中的应用。

一、微前端简介

微前端(Micro Frontends)是一种将大型单页应用拆分为多个独立的小型应用的技术方案。每个小型应用都可以独立开发、部署和运行,它们之间通过共享公共资源(如样式、组件等)来实现数据和状态的同步。微前端的核心思想是将前端应用分解为一组可独立维护、独立部署的子应用,从而提高开发效率、降低维护成本,同时保证系统的灵活性和可扩展性。

二、微前端的优势

1. 高度模块化

微前端将大型应用拆分为多个小型应用,每个应用负责一个特定的功能或模块。这种模块化的设计使得开发者可以更加专注于某个功能的开发,提高开发效率。

2. 独立部署

每个微应用都可以独立部署,无需对整个应用进行整体部署。这大大简化了部署过程,降低了部署风险。

3. 易于扩展

当需要添加新功能时,只需开发一个新的微应用并将其集成到主应用中,而无需修改现有的代码。这使得系统具有良好的可扩展性。

4. 技术栈无关

微前端允许每个微应用使用不同的技术栈,这为团队提供了更大的技术选择空间,同时也降低了技术选型的风险。

5. 独立升级

当某个微应用需要升级时,只需对该应用进行升级,而不会影响其他应用。这有助于保持整个系统的稳定和可靠。

三、微前端的原理

微前端的核心原理是通过定义一个容器来承载多个独立的微应用。这个容器负责管理各个微应用之间的通信和资源共享。具体来说,微前端主要包括以下几个部分:

  1. 主应用:主应用是整个系统的入口,它负责加载和管理各个微应用。主应用通常包含一个容器元素,用于承载各个微应用的内容。此外,主应用还需要提供一些基础设施服务,如路由管理、状态管理等。

  2. 微应用:微应用是主应用中的一个子应用,它可以独立开发、部署和运行。每个微应用都包含一个容器元素,用于承载该应用的内容。此外,微应用还需要提供一些与主应用交互的接口,如共享资源、通信等。

  3. 通信机制:微前端需要实现各个微应用之间的通信和资源共享。这通常通过定义一套统一的通信协议和API来实现。例如,可以使用自定义事件、消息队列等方式来实现微应用之间的通信;可以使用Webpack、Rollup等打包工具来实现资源的共享和提取。

四、微前端案例思路

下面我们通过一个简单的案例思路来模拟如何使用微前端技术构建一个高效的前端应用。假设我们要开发一个包含多个子功能的在线教育平台,如课程管理、在线考试、学习社区等。我们可以采用以下步骤来实现这个系统:

  1. 拆分功能模块:首先,我们需要将整个在线教育平台拆分为多个独立的功能模块,如课程管理模块、在线考试模块、学习社区模块等。每个模块都可以作为一个独立的微应用进行开发和维护。

  2. 设计通信协议:为了实现各个微应用之间的通信和资源共享,我们需要设计一套统一的通信协议和API。例如,我们可以定义一个emit方法来触发自定义事件,以及一个on方法来监听自定义事件;我们还可以使用Webpack的CommonsChunkPlugin插件来实现公共资源的提取和共享。

  3. 开发主应用:主应用是整个在线教育平台的入口,它负责加载和管理各个微应用。主应用需要提供一个容器元素来承载各个微应用的内容,并提供一些基础设施服务,如路由管理、状态管理等。此外,主应用还需要实现与各个微应用的通信和资源共享。

  4. 开发微应用:每个微应用都是一个独立的功能模块,它可以独立开发、部署和运行。每个微应用都需要提供一个容器元素来承载该应用的内容,并提供一些与主应用交互的接口,如共享资源、通信等。此外,微应用还需要实现自身的业务逻辑和界面展示。

  5. 集成测试:在完成各个微应用的开发后,我们需要对整个系统进行集成测试,确保各个微应用之间的通信和资源共享正常工作。此外,我们还需要对整个系统的性能、稳定性等进行测试和优化。


《微前端实战》

在这里插入图片描述

编辑推荐

就像微服务为后端系统带来了灵活性和可维护性,微前端也为基于浏览器的应用程序提供了同样的优势。你可以将项目设计为包含多个单独的组件,每个组件中包括各自的接口、逻辑和存储功能,这样就可以独立开发这些组件,并在浏览器中组合使用它们。

《微前端实战》一书指导读者将微服务方法应用于前端领域。本书首先会介绍微前端的核心设计思想,之后你将亲手创建一个电商应用程序,并在开发过程中处理一些实际问题,如服务端组合和客户端组合、路由、确保外观和交互的一致性等。最终,你将深入了解团队工作流模式,这种模式能够化地突显独立开发应用程序组件的优势。

内容简介

  • 将多个独立的应用程序组合成一个统一的前端应用程序

  • 将基于不同框架的代码组合在一起

  • 浏览器端组合、服务端组合以及路由

  • 高效的开发团队实践和项目工作流

作者简介

Michael Geers是一名软件开发者,专注于用户界面相关开发领域。他从十几岁起就开始为网站开发软件。在过去的几年里,他参与过多个垂直架构的项目,在多个国际性会议上分享了自己的经验,并在杂志上发表了一系列相关的文章。目前,他仍在持续运营https://micro-frontends.org站点。

目录

第Ⅰ部分 微前端初体验第1章 什么是微前端 31.1 概览图 41.1.1 系统和团队 51.1.2 前端 81.1.3 前端集成 111.1.4 公共话题 131.2 微前端解决了哪些问题 141.2.1 优化功能开发 141.2.2 不再有前端巨石架构 151.2.3 适应变化 161.2.4 自主的优势 191.3 微前端的缺点 211.3.1 冗余 211.3.2 一致性 211.3.3 异质性 221.3.4 更多的前端代码 221.4 使用微前端的合理时机 231.4.1 适合大中型项目 231.4.2 在Web应用程序中使用效果最好 231.4.3 效率与开销 241.4.4 微前端不适用的场景 251.4.5 谁在使用微前端 261.5 本章小结 26第2章 我的第一个微前端项目 292.1 The Tractor Store简介 302.1.1 准备开始 302.1.2 运行书中的示例代码 322.2 通过链接进行页面跳转 352.2.1 数据所有权 352.2.2 团队契约 362.2.3 如何实现 372.2.4 处理URL的变化 402.2.5 优点 412.2.6 缺点 422.2.7 何时使用链接集成技术 422.3 通过iframe进行组合 422.3.1 如何实现 432.3.2 优点 452.3.3 缺点 452.3.4 何时使用iframe集成技术 462.4 内容预告 462.5 本章小结 47第Ⅱ部分 路由、组合与通信第3章 使用Ajax进行组合与服务端路由 513.1 通过Ajax进行组合 523.1.1 如何实现 533.1.2 样式与脚本的命名空间 553.1.3 声明式地加载h-include 593.1.4 优点 593.1.5 缺点 613.1.6 何时使用Ajax集成 623.1.7 总结 623.2 通过Nginx实现服务端路由 633.2.1 如何实现 663.2.2 资源的命名空间 693.2.3 路由配置的方法 703.2.4 基础设施的归属 713.2.5 何时应使用单个域名 733.3 本章小结 73第4章 服务端组合 754.1 通过Nginx和服务端包含(SSI)进行组合 764.1.1 如何实现 774.1.2 更少的加载次数 804.2 处理不可靠的片段 814.2.1 可分离的片段 824.2.2 集成Near You片段 834.2.3 超时和回退 844.2.4 回退内容 864.3 深入研究标签的组装性能 874.3.1 并行加载 874.3.2 嵌套的片段 884.3.3 延迟加载 894.3.4 首字节时间和流式输出 904.4 其他解决方案概述 924.4.1 Edge-Side Includes 924.4.2 Zalando Tailor 934.4.3 Podium 954.4.4 哪种方案更适合 1024.5 服务端组合的优缺点 1044.5.1 优点 1044.5.2 缺点 1044.5.3 使用服务端集成的时机 1054.6 本章小结 106第5章 客户端组合 1075.1 使用Web Component封装微前端 1085.1.1 如何实现 1105.1.2 将框架封装在Web Component内 1155.2 使用Shadow DOM实现样式隔离 1175.2.1 创建shadow root 1175.2.2 样式隔离 1185.2.3 何时使用Shadow DOM 1205.3 使用Web Component进行组合的优缺点 1215.3.1 优点 1215.3.2 缺点 1225.3.3 使用客户端集成的时机 1225.4 本章小结 123第6章 通信模式 1256.1 用户界面通信 1266.1.1 父级页面到片段 1276.1.2 片段到父级页面 1316.1.3 片段到片段 1356.1.4 使用Broadcast Channel API发布/订阅 1406.1.5 UI通信更适合什么场景 1426.2 其他通信机制 1436.3 本章小结 148第7章 客户端路由和应用程序容器 1497.1 应用程序容器中的扁平化路由 15217.2 双层路由的应用程序容器 1627.3 single-spa元框架的简述 1717.4 来自统一单页面应用的挑战 1787.5 本章小结 183第8章 组合和多端渲染 1858.1 结合使用服务端和客户端组合 1878.2 何时适合采用多端组合 1958.3 本章小结 197第9章 适合我们项目的架构 1999.1 复习专业术语 2009.2 复杂度的比较 2069.3 是构建网站还是应用程序 2089.4 选择正确的架构和集成技术 2119.5 本章小结 216第Ⅲ部分 如何做到快速、一致、有效第10章 资源加载 22110.1 资源引用策略 22210.2 打包粒度 23810.3 按需加载 24110.4 本章小结 242第11章 至关重要的性能 24311.1 高性能架构设计 24411.2 精简并复用vendor库 25111.3 本章小结 272第12章 UI设计系统 27512.1 为什么需要一个设计系统 27612.2 公用设计系统与自治团队 27912.3 运行时整合与构建时整合 28612.4 样式库中的组件:通用与定制 29312.5 哪些组件应该沉淀到中心化的样式库中 29812.6 本章小结 303第13章 团队及职责边界 30513.1 将系统与团队对齐 30613.2 知识分享 31413.3 横向共性问题 31713.4 技术多样性 31913.5 本章小结 323第14章 迁移、本地开发及测试 32514.1 迁移 32614.2 本地开发 33314.3 测试 33914.4 本章小结 341

前言/序言

我是一名有着20年经验的Web开发人员。在这20年中,我参与了各种规模的项目,其中包括独自一人开发的微型创业项目,与其他几位同伴一同完成的小型项目,也参与过多人合作的大型项目(人数肯定超过了我家餐桌旁摆放的椅子数量)。

2014年,我和neuland Büro für Informatik的同事们负责为一家连锁百货公司重建电子商务系统。其现有的电子商务系统不仅存在性能问题,而且结构非常混乱,在其基础上开发新的功能需要耗费很长时间,通常还会引发系统其他功能的故障。随着相关开发团队规模的逐渐扩大,系统愈发难以维护。客户要求新的系统除了具有更加合理的架构外,还希望在此架构上,不同的开发团队能够独立开展工作,互不影响。这种并行开发的能力,对于客户以信息化为基础快速扩张业务的计划,有着至关重要的意义。为此,我们选择了一种“垂直化”的系统架构:按照职能划分,设立多个独立的团队,每个团队专门负责一块特定业务的开发,包括从数据库到前端页面展示的所有工作。这样每个团队所负责开发的部分都是独立和自治的,最终会在前端页面层面整合在一起。从概念上来看,前端整合似乎没有什么难度,但事实上我们需要掌握大量的知识才能有效地实现前端整合。随着项目的深入,我们逐步完善了所采用的技术,并从实践中总结了大量经验。

与此同时,其他公司也在采用类似的技术方案。然而业界对这种方案没有一个统一的命名。每当我想通过搜索引擎了解多个独立且自治的团队在共同完成一个Web应用程序所面临的挑战时,总是无法找到合适的搜索词来恰当地描述我的意图。在2016年11月,ThoughtWorks Technology Radar将这种技术方案命名为“微前端”,这一术语的出现更加便于大家在开发社区中围绕一致的技术架构分享最佳实践、技术和工具。

在2017年的夏天,我抽空对实践中的一些经验进行了总结。将所使用的技术凝结为独立的示例项目,并发布到https://micro-frontends.org上。从那时起,情况发生了一些变化,我被邀请在各种会议上发言,也收到了许多杂志社的约稿。社区中的开发人员还将网站翻译成各种语言。

最重要的是,去年年初,Manning出版社的Nicole和Brian找到了我。他们邀请我写一本关于微前端的书。收到邀请时我首先想到的是:“这有点离谱,我可不是一名作家!我甚至不喜欢阅读文字,而更喜欢倾听、编写代码、搭建系统以及解决问题”。但这看起来又是一个千载难逢的机会,在给出答复之前我经过了慎重考虑,并与家人和朋友讨论了多次。最后我决定抓住机会,接受这个邀请。毕竟,我非常喜欢表达和阐述。将思考总结成书,以图(我非常喜欢图)和代码示例的方式呈现,对我来说也是一种挑战,在整个过程中我也能学到很多东西。回顾编写本书的历程,我很满意当初的决定,以及这个决定的最终产物,也就是各位现在看到的这本书。

相关文章:

微前端实战:打造高效、灵活的前端应用架构

文章目录 一、微前端简介二、微前端的优势1. 高度模块化2. 独立部署3. 易于扩展4. 技术栈无关5. 独立升级 三、微前端的原理四、微前端案例思路《微前端实战》编辑推荐内容简介作者简介目录前言/序言 随着互联网行业的快速发展,前端应用的规模和复杂度也在不断增加。…...

csv文件EXCEL默认打开乱码问题

这里讨论的问题是,当用记事本打开带有中文字符的csv正常时,用excel打开却是乱码。 简单概括就是:编码问题,windows的 excel打开csv文本文件时,默认使用的是系统内的ANSI,在中文环境下就是GB2312。如果写文件…...

C语言之实现贪吃蛇小游戏篇(2)

目录 🎇测试游戏test.c 🎇游戏头文件包含&函数声明snake.h 🎇游戏实现snake.c 🎇测试游戏test.c #define _CRT_SECURE_NO_WARNINGS 1 #include "snake.h" void test() {int ch 0;do{Snake snake { 0 };//创建…...

Comparator接口

Comparator接口 Comparator 是 Java 中用于比较对象的接口。它允许开发者实现自定义的比较逻辑,以用于对对象进行排序或者确定它们的顺序。 主要方法: Comparator 接口中包含一个抽象方法: int compare(T o1, T o2):用于比较两…...

SELinux refpolicy详解(9)

接前一篇文章:SELinux refpolicy详解(8) 三、refpolicy内容详解 上一回讲解了refpolicy源码根目录下的build.conf文件的前一部分内容。本回继续讲解其后一部分。 2. build.conf 文件路径:refpolicy源码根目录/build.conf。 文…...

零基础上手,秒识别检测,IDEA研究院发布全新T-Rex模型

目标检测作为当前计算机视觉落地的热点技术之一,已被广泛应用于自动驾驶、智慧园区、工业检测和卫星遥感等场景。开发者在研究相关目标检测技术时,通常需熟练掌握图像目标检测框架,如通用目标检测框架 YOLO 系列,旋转目标检测框架…...

python每日一题——20旋转图像

题目 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 示例 1: 输入:matrix [[1,2,3],[4,5,6],[7,8,9]]…...

云计算生成式 -给你不一样的音乐推荐新体验

目录 摘要: 正文: 一、亚马逊云与生成式 AI 结合的展望/总结 二、我用亚马逊云科技生成式 AI 产品打造了什么,解决了什么问题 三、未来云端技术发展趋势的见解 四、云端技术未来需要解决的问题 1、如何保护数据安全和隐私? …...

Zabbix 6.0部署+自定义监控项+自动发现与自动注册+部署zabbix代理服务器

Zabbix 6.0 Zabbix 6.0一、关于zabbix1、什么是zabbix2、zabbix工作原理3、zabbix 6.0 特性4、zabbix 6.0 功能组件 二、Zabbix 6.0 部署1、 部署 zabbix 服务端(1) 部署 Nginx PHP 环境并测试(2) 部署数据库(3) 编译安装 zabbix server 服务端(4) 部署 Web 前端,进…...

Docker 简介及其常用命令详解

Docker 简介及其常用命令详解 Docker 自推出以来,已成为开发和运维领域的重要工具。它简化了应用的部署、测试和分发过程,使得容器化技术成为现代软件开发的标准实践。本文将为您提供Docker的基础介绍以及其常用命令的详细讲解。 什么是Docker&#xf…...

基于PHP的高中生物学习平台

有需要请加文章底部Q哦 可远程调试 基于PHP的高中生物学习平台 一 介绍 此高中生物学习平台基于原生PHP开发,数据库mysql。系统角色分为用户和管理员。(附带参考设计文档) 技术栈:phpmysqlphpstudyvscode 二 功能 学生 1 注册/登录/注销 2 个人中心 …...

Git多库多账号本地SSH连接配置方法

Git多库多账号本地SSH连接配置方法 一、前言二、环境三、帮助文档四、多环境配置4.1 配置config文件 五、生成RSA秘钥对5.1 ssh秘钥位置5.2 生成秘钥对(公钥、私钥)5.3 添加公钥到GIT用户配置中 六 测试git是否可以使用七、总结 一、前言 在使用Git管理…...

爬虫学习-基础(HTTP原理)

目录 一、URL和URI 二、HTTP和HTTPS (1)HTTP (2)HTTPS (3)HTTP与HTTPS区别 (4)HTTPS对HTTP的改进:双问的身份认证 三、TCP协议 (1)TCP三次握手…...

Gazebo 中为地面和车轮添加摩擦属性

Gazebo 中为地面和车轮添加摩擦属性 Link friction properties not applied from URDF to Gazebo SDFormat Specification Adding friction to model wheels Gazebo中模型自行滑动(后溜)的原因探究 移动机器人在仿真时,一旦以较大的速度启动&…...

【重点】【滑动窗口】3. 无重复字符的最长子串

题目 参考《算法小抄》重的解法&#xff0c;重点理解&#xff01;&#xff01;&#xff01; class Solution {public int lengthOfLongestSubstring(String s) {if (s.length() < 2) {return s.length();}char[] array s.toCharArray();int left 0, right 0, res 0;int…...

python初始化矩阵相关

做算法题经常需要初始化一个二维的dp数组 下面两种方法是最常用的 matrix [[0]*n]*n matrix [[0]*n for _ in range(n)]以前经常混用也没发现什么问题&#xff0c;直到昨天debug的时候发现第一种初始化之后对矩阵进行赋值时混乱的&#xff0c;比如matrix[0][1]2会导致所有行…...

C++ :运算符重载

运算符重载&#xff1a; 运算符重载概念&#xff1a;对已有的运算符重新进行定义&#xff0c;赋予其另一种功能&#xff0c;以适应不同的数据类型 运算符的重载实际是一种特殊的函数重载&#xff0c;必须定义一个函数&#xff0c;并告诉C编译器&#xff0c;当遇到该重载的运算符…...

如何跑通跨窗口渲染:multipleWindow3dScene

New 这是一个跨窗口渲染的示例&#xff0c;用 Three.js 和 localStorage 在同一源&#xff08;同产品窗口&#xff09;上跨窗口设置 3D 场景。而这也是本周推特和前端圈的一个热点&#xff0c;有不少人在争相模仿它的实现&#xff0c;如果你对跨窗口的渲染有兴趣&#xff0c;可…...

flutter-web中使用js工具类

文章目录 为什么要调用js1. flutter-web1. 引入js web/index.html2. 创建工具js web/CryptoEnc.js3. 创建对应的lib/js/js_interop.dart4. 由于引入的js是针对web平台的&#xff0c;所以引入需要做引入处理5. 使用 2. Android1. 引入依赖2. index.html3. dart引用 为什么要调用…...

@ResponseBody详解:用于响应体响应数据

RestFul风格或者是web阶段接触过的异步请求&#xff0c;都需要把数据转换成Json放入响应体中。 ResponseBody的作用其实是将java对象转为json格式的相应内容 使用 RequestMapping注解时&#xff0c;Spring会将返回值解析为视图路径&#xff0c;然后跳转路径返回对应的视图页面…...

【Python百练——第3练】矩形类及操作

&#x1f490;作者&#xff1a;insist-- &#x1f490;个人主页&#xff1a;insist-- 的个人主页 理想主义的花&#xff0c;最终会盛开在浪漫主义的土壤里&#xff0c;我们的热情永远不会熄灭&#xff0c;在现实平凡中&#xff0c;我们终将上岸&#xff0c;阳光万里 ❤️欢迎点…...

【C语言学习疑难杂症】C语言中数组存储时为什么从低地址到高地址

在C语言中&#xff0c;数组的存储从低地址到高地址是有其历史原因的。这种设计主要是为了与计算机系统的内存组织方式相一致。 在计算机系统中&#xff0c;内存通常按照字节进行编址&#xff0c;地址从低到高递增。数组在内存中是连续存储的&#xff0c;因此数组的第一个元素&…...

Linux:查看端口占用的进程

命令 netstat -tunlp可以从图中看到&#xff0c;端口被那个进程占用&#xff0c;对应进程的pid是多少。...

医美店会员管理系统预约小程序作用是什么

医美在美业中占据着一定地位&#xff0c;爱美使然和经济独立、悦己消费下&#xff0c;不少女性会前往医美机构做脸部整容、嫩肤补水等服务&#xff0c;如美容院一样都是具备本地外地属性的&#xff0c;因此在如今互联网盛行下&#xff0c;商家需要借势线上破解难题及增强生意效…...

Linux 正则表达式

内容概述 1 文本编辑工具之神 VIM 1.1 vi 和 vim 简介 在 Linux 中我们经常编辑修改文本文件&#xff0c;即由 ASCII Unicode 或者其他编码的纯文字的文件。之前介绍过的 nano&#xff0c;实际工具中我们使用更为专业&#xff0c;功能强大的工具 文本编辑种类&#xff1a; vi…...

C语言面试之数组指针上篇

C语言数组是C语言中重要的数据结构之一&#xff0c;它用于存储一组相同类型的数据。数组在C语言中是以连续的内存空间来存储的&#xff0c;每个数组元素都是一个变量&#xff0c;占据一定的内存空间&#xff0c;数组元素之间是紧密相邻的。 一、数组的定义 在C语言中&#xff0…...

LinkWeChat,唯一以开源为核心的SCRM

LinkWeChat是国内首个基于企业微信的开源SCRM&#xff0c;在集成了企微强大的开放能力的基础上&#xff0c;进一步升级拓展灵活高效的客户运营能力及多元化精准营销能力&#xff0c;让客户与企业之间建立强链接&#xff0c;帮助企业提高客户运营效率&#xff0c;强化营销能力&a…...

Android textView 显示: STRING_TOO_LARGE

在Android中&#xff0c;字符串资源的长度限制是32KB&#xff0c;getString()方法返回的字符串资源的大小超过这个限制&#xff0c;就会抛出STRING_TOO_LARGE 这个错误。 我本地的临界值是&#xff1a;32.3 KB (33,090 字节) 小于等于33090时&#xff0c;能正常显示&#xff…...

用HeidiSQL在MySQL中创建新的数据库

用有权限的用户登录&#xff1a; 右键单击&#xff0c;选择&#xff1a; 输入要创建的数据库名称&#xff0c;然后点击“确定”&#xff1a; 刷新下&#xff0c;就看到新创建的数据库了&#xff1a; 在新创建的数据库中&#xff0c;就可以做其它操作了&#xff0c;例如…...

纯前端实现导入excel数据

准备工作 - 下载 xlsx npm install xlsx下面直接上代码&#x1f447; <template><div><input type"file" accept".xlsx, .xls" change"handleClick"></div> </template><script langts setup> import * a…...