title: Vue微前端架构与Qiankun实践理论指南

date: 2024/6/15

updated: 2024/6/15

author: cmdragon

excerpt:

这篇文章介绍了微前端架构概念,聚焦于如何在Vue.js项目中应用Qiankun框架实现模块化和组件化,以达到高效开发和维护的目的。讨论了Qiankun的原理、如何设置主应用与子应用的通信,以及如何解决跨域问题和优化集成过程,从而实现前端应用的灵活扩展与组织。

categories:

  • 前端开发

tags:

  • 微前端
  • Vue.js
  • Qiankun
  • 框架
  • 架构
  • 通信
  • 集成

扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

第一章:微前端架构概述

微前端概念介绍

微前端是一种设计理念,它借鉴了微服务架构的思想,将一个庞大的前端应用拆分成多个独立的小型应用(微应用)。每个微应用可以独立开发、测试、部署和维护,并且可以独立运行。这些微应用通过一定的机制(如路由、事件总线等)集成在一起,形成一个完整的应用程序。微前端的核心思想是将前端应用分解为一组可独立维护、独立部署的子应用,从而提高开发效率、降低维护成本,同时保证系统的灵活性和可扩展性。

微前端架构的优势

  1. 技术栈无关:不同的团队可以使用不同的技术栈进行开发,例如,一个团队可以使用React,另一个团队可以使用Vue,而主应用可以使用Angular。这种灵活性使得团队能够选择最适合他们需求的技术栈。
  2. 独立部署:每个微应用可以独立部署,这意味着一个微应用的更新不会影响到其他微应用,从而提高了部署的灵活性和安全性。
  3. 易于扩展:随着项目的增长,可以轻松地添加新的微应用,而无需重构整个应用。这种模块化的设计使得应用更容易扩展和维护。
  4. 团队协作:微前端架构鼓励并行开发,不同的团队可以独立工作,互不干扰,从而提高了团队协作的效率。
  5. 可维护性:由于每个微应用都是独立的,因此它们可以独立维护,这有助于降低维护成本和提高维护效率。

微前端架构的挑战

  1. 通信复杂性:微应用之间的通信可能会变得复杂,需要设计良好的通信机制来确保数据的一致性和实时性。
  2. 样式隔离:确保微应用之间的样式不会相互干扰是一个挑战,需要使用CSS隔离技术来避免样式冲突。
  3. 性能问题:微前端架构可能会引入额外的性能开销,例如,微应用之间的加载和通信可能会影响应用的响应速度。
  4. 技术债务:随着时间的推移,不同的微应用可能会使用不同的技术栈和版本,这可能导致技术债务的积累。

微前端架构的应用场景

  1. 大型企业级应用:对于大型企业级应用,微前端架构可以帮助管理复杂的代码库,提高开发效率。
  2. 多团队协作项目:在多团队协作的项目中,微前端架构可以减少团队之间的依赖,提高协作效率。
  3. 遗留系统现代化:对于需要现代化的遗留系统,微前端架构可以逐步替换旧的功能模块,而不影响整个系统的运行。
  4. 多租户应用:在多租户应用中,微前端架构可以允许每个租户拥有自己的前端应用,同时共享后端服务。

第二章:Vue与微前端

Vue.js的介绍

Vue.js 是一个渐进式 JavaScript 框架,用于构建用户界面。它易于上手,同时提供了丰富的功能,使得它非常适合构建复杂的单页应用(SPA)。Vue.js

的核心库专注于视图层,易于与第三方库或已有项目整合。此外,Vue.js 还提供了 Vue Router 用于页面路由和 Vuex 用于状态管理,以及

Vue CLI 用于快速搭建项目。

Vue.js在微前端架构中的应用

在微前端架构中,Vue.js 可以作为一个独立的微应用来使用。每个微应用可以独立开发、测试和部署,然后通过一定的集成机制(如路由、事件总线等)与其他微应用集成在一起。Vue.js

的模块化设计使得它非常适合微前端架构,因为它允许开发者将应用拆分成多个可复用的组件。

Vue.js与其他前端框架的集成

Vue.js 可以与其他前端框架集成,例如 React 或 Angular。这种集成可以通过以下几种方式实现:

  1. 共享库:可以创建一个共享库,包含一些通用的组件或工具函数,这些可以在不同的微应用中使用,无论它们是基于 Vue.js 还是其他框架。
  2. 微应用容器:可以使用微应用容器(如 Single-SPA)来集成不同的微应用。这些容器可以管理不同框架的微应用的生命周期,并提供通信机制。
  3. 自定义集成:如果需要更精细的控制,可以编写自定义的集成代码,以实现不同框架之间的通信和状态共享。
  4. API网关:对于后端服务,可以使用 API 网关来统一不同微应用的后端接口,使得前端应用可以无缝地调用后端服务。
  5. 事件总线:可以使用事件总线来实现微应用之间的通信,无论它们是基于 Vue.js 还是其他框架。

第三章:Qiankun框架介绍

Qiankun框架的起源与发展

Qiankun 是一个由蚂蚁金服开源的企业级微前端框架,它允许你将不同框架开发的应用作为微应用集成到主应用中,同时保持每个微应用的独立性和完整性。Qiankun

的名字来源于中国古代神话中的“千钧一发”,寓意着它能够承载大量的微应用,并且能够在关键时刻发挥作用。

Qiankun 的起源可以追溯到蚂蚁金服内部对微前端架构的需求,随着微前端架构的流行,Qiankun

逐渐发展成为一个成熟的微前端解决方案,并在开源社区中获得了广泛的关注和认可。

Qiankun框架的核心概念

Qiankun 的核心概念包括:

  1. 微应用:指被集成到主应用中的独立应用,可以是基于任何前端框架开发的。
  2. 主应用:指承载和管理微应用的容器应用,通常负责微应用的加载、卸载、通信等。
  3. 沙箱:Qiankun 使用沙箱技术来隔离微应用之间的运行环境,确保它们不会相互干扰。
  4. 基座应用:在 Qiankun 中,主应用也被称为基座应用,它是整个微前端架构的入口。

Qiankun框架的架构设计

Qiankun 的架构设计主要包括以下几个部分:

  1. 入口:微应用的入口通常是它的 HTML 文件,Qiankun 通过加载这个 HTML 文件来启动微应用。
  2. 生命周期:Qiankun 管理微应用的生命周期,包括加载、挂载、卸载等。
  3. 通信:Qiankun 提供了全局的状态管理机制,允许微应用之间进行通信。
  4. 样式隔离:Qiankun 使用 Shadow DOM 或 CSS 隔离技术来防止样式冲突。
  5. 沙箱:Qiankun 使用沙箱技术来隔离微应用的运行环境,确保它们不会相互干扰。

Qiankun框架的功能特点

Qiankun 的功能特点包括:

  1. 轻量级:Qiankun 本身非常轻量,不会对主应用或微应用造成负担。
  2. 高性能:Qiankun 的架构设计保证了微应用的加载和运行效率。
  3. 易用性:Qiankun 提供了简单的 API 和配置选项,使得集成微应用变得容易。
  4. 可扩展性:Qiankun 的设计允许开发者根据需要扩展其功能。
  5. 社区支持:Qiankun 拥有一个活跃的开源社区,提供了丰富的文档和示例。
  6. 沙箱技术:Qiankun 使用沙箱技术来隔离微应用的运行环境,确保它们不会相互干扰。
  7. 样式隔离:Qiankun 使用 Shadow DOM 或 CSS 隔离技术来防止样式冲突。
  8. 全局状态管理:Qiankun 提供了全局的状态管理机制,允许微应用之间进行通信。

第四章:Qiankun框架安装与配置

Qiankun框架的安装方法

Qiankun 框架的安装通常涉及到以下步骤:

  1. 环境准备:确保你的开发环境中已经安装了 Node.js 和 npm 或 yarn。

  2. 创建项目:使用脚手架工具创建一个新的项目,或者将 Qiankun 集成到现有的项目中。

  3. 安装 Qiankun:在项目目录下,运行以下命令来安装 Qiankun:

    npm install qiankun
    
    

    或者使用 yarn:

    yarn add qiankun
    
    
  4. 集成 Qiankun:根据你的项目类型(如 React、Vue、Angular 等),按照 Qiankun 官方文档的指引进行集成。

Qiankun框架的基本配置

Qiankun 的基本配置通常包括以下几个部分:

  1. 注册微应用:在主应用中,使用registerMicroApps方法来注册微应用,包括微应用的名称、入口、容器等信息。
  2. 启动 Qiankun:在主应用中,使用start方法来启动 Qiankun,并配置一些全局的生命周期钩子。
  3. 配置路由:根据需要配置主应用的路由,以便正确地加载和切换微应用。

Qiankun框架的高级配置

Qiankun 的高级配置包括但不限于:

  1. 沙箱配置:可以配置沙箱的类型(如 LegacySandbox、StrictSandbox 等)以及沙箱的运行模式。
  2. 样式隔离:可以配置样式隔离的策略,如使用 Shadow DOM 或 CSS 隔离。
  3. 全局状态管理:可以配置全局状态管理,如使用 Redux、Vuex 等。
  4. 生命周期钩子:可以配置微应用的生命周期钩子,如加载前、加载后、挂载前、挂载后、卸载前、卸载后等。
  5. 通信:可以配置微应用之间的通信机制,如使用全局事件总线、Redux 等。
  6. 加载微应用:可以配置微应用的加载策略,如使用 prefetch、lazy 等。
  7. 错误处理:可以配置错误处理机制,如使用全局错误处理器。
  8. 自定义渲染:可以配置自定义渲染逻辑,如使用自定义的加载动画、错误页面等。
  9. 权限控制:可以配置权限控制机制,如使用路由守卫、权限验证等。
  10. 日志记录:可以配置日志记录机制,如使用 console.log、第三方日志库等。

第五章:Vue微前端项目搭建

Vue微前端项目的规划

在搭建Vue微前端项目之前,需要进行详细的规划,包括:

  1. 需求分析:明确项目的需求,包括功能需求、性能需求、安全需求等。
  2. 技术选型:选择合适的技术栈,包括前端框架(Vue)、构建工具(Webpack)、状态管理(Vuex)、路由管理(Vue Router)等。
  3. 架构设计:设计项目的架构,包括微应用划分、通信机制、状态管理、样式隔离等。
  4. 开发流程:制定开发流程,包括开发规范、代码审查、版本控制等。
  5. 部署策略:制定部署策略,包括部署环境、部署流程、监控机制等。

Vue微前端项目的搭建步骤

搭建Vue微前端项目通常包括以下步骤:

  1. 环境准备:安装Node.js、npm或yarn,并配置好开发环境。
  2. 创建主应用:使用Vue CLI创建主应用,并配置好项目的基本结构。
  3. 创建微应用:使用Vue CLI创建微应用,并配置好项目的基本结构。
  4. 集成Qiankun:在主应用和微应用中集成Qiankun框架,并配置好相关参数。
  5. 配置路由:配置主应用和微应用的路由,以便正确地加载和切换微应用。
  6. 样式隔离:配置样式隔离策略,如使用Shadow DOM或CSS隔离。
  7. 状态管理:配置状态管理策略,如使用Vuex或Redux。
  8. 通信机制:配置微应用之间的通信机制,如使用全局事件总线或Redux。
  9. 测试:进行单元测试、集成测试和性能测试,确保项目质量。
  10. 部署:将项目部署到生产环境,并进行监控和维护。

Vue微前端项目的目录结构

Vue微前端项目的目录结构通常包括以下几个部分:

  1. 主应用

    • src/:源代码目录

      • assets/:静态资源目录
      • components/:公共组件目录
      • views/:页面目录
      • App.vue:主组件
      • main.js:入口文件
    • public/:公共资源目录

    • package.json:项目配置文件

    • vue.config.js:Vue CLI配置文件

  2. 微应用

    • src/:源代码目录

      • assets/:静态资源目录
      • components/:公共组件目录
      • views/:页面目录
      • App.vue:主组件
      • main.js:入口文件
    • public/:公共资源目录

    • package.json:项目配置文件

    • vue.config.js:Vue CLI配置文件

  3. Qiankun配置

    • src/micro-apps.js:微应用注册配置文件
    • src/lifecycles.js:生命周期钩子配置文件
  4. 其他

    • .eslintrc.js:ESLint配置文件
    • .gitignore:Git忽略文件
    • README.md:项目说明文件

第六章:Vue微前端项目开发

Vue微前端项目的开发流程

Vue微前端项目的开发流程通常包括以下几个步骤:

  1. 需求分析:明确每个微应用的功能需求,确定开发任务和目标。
  2. 技术选型:根据需求选择合适的技术栈,包括前端框架(Vue)、构建工具(Webpack)、状态管理(Vuex)、路由管理(Vue Router)等。
  3. 架构设计:设计每个微应用的架构,包括组件划分、状态管理、路由配置等。
  4. 编码实现:根据设计文档进行编码实现,包括编写Vue组件、配置Vuex状态管理、设置Vue Router路由等。
  5. 单元测试:编写单元测试用例,对组件和功能进行测试,确保代码质量。
  6. 集成测试:将微应用集成到主应用中,进行集成测试,确保微应用之间能够正常通信和协作。
  7. 性能优化:对项目进行性能优化,包括代码优化、资源优化、网络优化等。
  8. 部署上线:将项目部署到生产环境,并进行监控和维护。

Vue微前端项目的开发工具

Vue微前端项目的开发工具通常包括以下几个:

  1. 编辑器:如VSCode、Sublime Text、WebStorm等,用于编写代码。
  2. 构建工具:如Webpack、Vite等,用于打包和构建项目。
  3. 版本控制:如Git,用于管理代码版本和协作开发。
  4. 调试工具:如Chrome DevTools、Vue DevTools等,用于调试和优化代码。
  5. 测试工具:如Jest、Mocha、Chai等,用于编写和执行测试用例。
  6. 性能监控工具:如Lighthouse、WebPageTest等,用于监控和分析项目性能。

Vue微前端项目的开发技巧

Vue微前端项目的开发技巧包括以下几个:

  1. 组件化开发:将页面拆分成独立的Vue组件,提高代码的可维护性和复用性。
  2. 状态管理:使用Vuex或Redux等状态管理库,集中管理应用状态,方便数据共享和状态更新。
  3. 路由管理:使用Vue Router或React Router等路由管理库,配置路由规则,实现页面跳转和参数传递。
  4. 样式隔离:使用CSS Modules或Shadow DOM等技术,实现样式隔离,避免样式冲突。
  5. 代码分割:使用Webpack的代码分割功能,将代码拆分成多个块,按需加载,提高页面加载速度。
  6. 懒加载:使用Vue的异步组件或Webpack的懒加载功能,实现组件的懒加载,提高页面加载速度。
  7. 性能优化:使用Lighthouse、WebPageTest等工具,对项目进行性能分析,并进行优化,提高页面性能。
  8. 单元测试:编写单元测试用例,对组件和功能进行测试,确保代码质量。
  9. 集成测试:将微应用集成到主应用中,进行集成测试,确保微应用之间能够正常通信和协作。
  10. 持续集成:使用Jenkins、Travis CI等持续集成工具,自动化构建、测试和部署流程。

附录

Vue微前端项目相关资源

  1. 官方文档:Vue.js 官方文档提供了关于 Vue 微前端架构的详细信息和指南,包括如何使用 Vue.js 进行微前端开发。

  2. 社区论坛:Vue.js 社区论坛是一个活跃的地方,开发者可以在这里提问、分享经验和资源。

  3. 开源项目:GitHub 上有许多开源的 Vue 微前端项目,可以提供参考和学习的案例。

  4. 教程和博客:网络上有很多关于 Vue 微前端开发的教程和博客,可以帮助开发者学习和掌握相关技术。

  5. 微前端框架:如 qiankun、single-spa、wujie 等,这些框架提供了微前端架构的实现,可以帮助开发者快速搭建微前端项目。

Vue微前端项目常见问题解答

  1. 什么是微前端?微前端是一种将多个小型前端应用组合成一个大型应用的架构方式,每个应用负责一部分功能,可以独立开发和部署。

  2. 为什么使用微前端?使用微前端可以提高开发效率、可维护性、可扩展性、用户体验和安全性。

  3. 如何选择微前端框架?选择微前端框架时,需要考虑框架的稳定性、社区支持、文档完善程度、功能丰富程度等因素。

  4. 如何进行微前端项目的部署?微前端项目的部署需要考虑各个应用的独立部署和协同部署,可以使用容器化技术或云服务进行部署。

  5. 如何处理微前端项目中的样式冲突?可以通过 CSS 隔离、命名空间、CSS-in-JS 等技术来处理微前端项目中的样式冲突。

Vue微前端项目开发工具介绍

  1. Vue CLI:Vue CLI 是 Vue.js 官方提供的脚手架工具,可以帮助开发者快速搭建 Vue 项目,包括微前端项目。

  2. Webpack:Webpack 是一个现代 JavaScript 应用程序的静态模块打包器,可以用于构建 Vue 微前端项目。

  3. qiankun:qiankun 是一个基于 single-spa 的微前端框架,提供了微前端架构的实现,可以帮助开发者快速搭建微前端项目。

  4. single-spa:single-spa 是一个用于构建微前端架构的 JavaScript 库,可以用于构建 Vue 微前端项目。

  5. wujie:wujie 是一个基于 Web Components 的微前端框架,提供了微前端架构的实现,可以帮助开发者快速搭建微前端项目。

Vue微前端架构与Qiankun实践理论指南的更多相关文章

  1. 微前端大赏二-singlespa实践

    微前端大赏二-singlespa实践 微前端大赏二-singlespa实践 序 介绍singleSpa singleSpa核心逻辑 搭建环境 vue main react child 生命周期 结论 ...

  2. 微前端框架 之 qiankun 从入门到源码分析

    封面 简介 从 single-spa 的缺陷讲起 -> qiankun 是如何从框架层面解决 single-spa 存在的问题 -> qiankun 源码解读,带你全方位刨析 qianku ...

  3. 《OneForAll框架搭建之旅》前端篇:微前端架构设计(Vue)

    心之所向,勇往直前!记录开发过程中的那些小事,给自己加点经验值. 前言 作为一个.Net后端开发,在竞争愈加激烈的当下,掌握点前端配菜好像已经是家常便饭了. 刚好在工作的第5个年头,辞去小主管职务的我 ...

  4. .NET Core微服务架构学习与实践系列文章索引目录

    一.为啥要总结和收集这个系列? 今年从原来的Team里面被抽出来加入了新的Team,开始做Java微服务的开发工作,接触了Spring Boot, Spring Cloud等技术栈,对微服务这种架构有 ...

  5. Spring Cloud 微服务架构全链路实践

    阅读目录: 1. 网关请求流程 2. Eureka 服务治理 3. Config 配置中心 4. Hystrix 监控 5. 服务调用链路 6. ELK 日志链路 7. 统一格式返回 Java 微服务 ...

  6. jquery/vue/react前端多语言国际化翻译方案指南

    ❝ 本文章共3470字,预计阅读时间5-10分钟. ❞ 国际化-前言 每个开发者能希望编写的程序可以让全世界的用户使用,它要求从产品中抽离所有地域语言,国家/地区和文化相关的元素.换种说法,「应用程序 ...

  7. vivo 商品中台的可视化微前端实践

    一.背景 在电商领域内,商品是一个重要组成部分,与其对应的商品管理系统,则负责商品的新建.编辑.复制等功能.随着商品管理系统的成熟稳定和业务上的扩展需求,催化出了商品中台的诞生.它可以将现有商品功能最 ...

  8. 初步认识微前端(single-spa 和 qiankun)

    初步认识微前端 微前端是什么 现在的前端应用,功能.交互日益复杂,若只由一个团队负责,随着时间的推进,会越来越庞大,愈发难以维护. 微前端这个名词,第一次提出是在2016年底.它将微服务(将单一应用程 ...

  9. 全链路实践Spring Cloud 微服务架构

    Spring Cloud 微服务架构全链路实践Spring Cloud 微服务架构全链路实践 阅读目录: 网关请求流程 Eureka 服务治理 Config 配置中心 Hystrix 监控 服务调用链 ...

  10. Node.js躬行记(9)——微前端实践

    后台管理系统使用的是umi框架,随着公司业务的发展,目前已经变成了一个巨石应用,越来越难维护,有必要对其进行拆分了. 计划是从市面上挑选一个成熟的微前端框架,首先选择的是 icestark,虽然文档中 ...

随机推荐

  1. 直播回顾:如何对付臭名昭著的 IO 夯?诊断利器来了 | 龙蜥技术

    ​简介:听到IO夯总是让人头疼,那有没有可以分析IO夯问题的利器? 编者按:sysAK(system analyse kit),是龙蜥社区(OpenAnolis)系统运维 SIG 下面的一个开源项目, ...

  2. GitLab 升级迁移待办清单

    GitLab 大版本升级测试用例 项目 从模板项目 URL 导入,来创建新的项目 议题 通过 Quick Actions.关联新建.直接新建 模板 关联项 标签 工时 评论 看板 里程碑 分支 通过 ...

  3. 超级详细的PostgreSQL创建数据库操作并附带图文

    首发微信公众号:SQL数据库运维 原文链接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485195&idx=1 ...

  4. fastposter v2.9.2 最简海报生成器

    fastposter v2.9.2 程序员必备海报生成器 fastposter海报生成器是一款快速开发海报的工具.只需上传一张背景图,在对应的位置放上组件(文字.图片.二维.头像)即可生成海报. 点击 ...

  5. python教程3.1:数据类型:字符串+列表list

    一.字符串 字符串是⼀个有序的字符的集合,⽤于在计算机⾥存储和表示⽂本信息  常用方法--str.fun() 全局函数 二.列表list []内以逗号分隔,按照索引,存放各种数据类型,每个位置代表⼀个 ...

  6. MSP 通过 Splashtop SOS 远程支持非托管设备

    RMM 是 MSP 的绝佳工具.它们使 MSP 可以通过集中控制台来管理其所有客户计算机,通常使他们能够远程访问任何计算机以提供远程支持. 但是,这样做的一个很大限制是--并非所有客户设备都在 MSP ...

  7. 基于webapi的websocket聊天室(番外一)

    上一篇我已经实现了聊天室,并且在协议中实现了4种类型的消息传输.其实还可以添加video,audio,live等等类型. 不过假如把目前的协议看作RCP1.0版的话,这个版本就只支持有限的4种消息.精 ...

  8. C# Log4net 组件无法写日志 IsDebuged、IsInfoEnabled、IsErrorEnabled 全部为false

    [assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)] 如果 ...

  9. winform cefsharp chart.js 再winform上使用chart.js 绘制动态曲线

    CefSharp 是一款开源的使用.net平台基于谷歌的 封装浏览器组件,可用于winform wpf . chart.js 也是一款开源的图表展示组件. 我所作的就是使用这两个组件再winform上 ...

  10. mac for docker访问宿主机服务

    转载链接 https://blog.csdn.net/weixin_33860528/article/details/91461648