0

0

使用Vue Vite和模块联合会建造微观前端体系结构

DDD

DDD

发布时间:2025-02-08 20:00:33

|

613人浏览过

|

来源于php中文网

原创

使用vue vite和模块联合会建造微观前端体系结构

微前端架构已成为构建可扩展、模块化应用程序的流行方法。它将整体前端拆分成更小、独立的微前端 (MFEs),从而实现团队独立开发、单独部署和提升可维护性。本文将探讨一个基于 Vue 3、Vite 和 Module Federation 的微前端示例,并利用动态路由管理构建灵活、可扩展的架构。

在每个微前端都需要自身 Vue 实例的情况下,这种方法尤为有效,允许团队在避免依赖冲突的情况下开发和维护独立的前端服务。此外,该架构仅加载必要的 Vue 实例,确保性能良好,同时保持微前端间的隔离。我们使用 Module Federation 运行时和路由清单在运行时动态获取和加载 MFEs。这意味着 MFEs 不会打包到主应用程序中,而是在需要时按需加载,从而提升灵活性并减少初始加载时间。

微前端架构概述 以下是我们微前端设置的工作原理概述:

+----------------+      +------------------+      +------------------+ 
|  主应用      |      |  微前端 1      |      |  微前端 2      |
|  (Vue Router)  |      |  (app-1)         |      |  (app-2)         |
|  loader.vue    |      |  Vue 实例      |      |  Vue 实例      |
+----------------+      +------------------+      +------------------+
  1. 主应用 处理路由并在运行时动态加载 MFEs。
  2. loader.vue 负责根据路由变化安装和卸载微前端。
  3. 每个微前端 拥有自己的 Vue 实例独立运行,并通过 Module Federation 公开组件。

快速上手 克隆仓库并安装依赖:

git clone https://github.com/lmlong-huynh/micro-frontend-sample.git
cd micro-frontend-sample
npm install

启动所有微前端和主应用:

npm run dev

或者单独启动每个微前端:

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

Detect GPT
Detect GPT

一个Chrome插件,检测您浏览的页面是否包含人工智能生成的内容

下载
cd packages/host && npm run dev
cd packages/app-1 && npm run dev
cd packages/app-2 && npm run dev

路由清单配置 路由清单在主应用中动态注册微前端路由。所有路由都指向 loader.vue,而不是直接引用远程应用。清单中,我们定义两个属性:一个指定路由对象,另一个指示哪个 MFE 以及从哪里加载。

// routeManifest.js
export const routeManifest = [
  {
    route: {
      path: '/app-1',
      name: 'app1',
      meta: { requiresAuth: false },
    },
    remote: { module: 'app1/app' }
  },
  {
    route: {
      path: '/app-2',
      name: 'app2',
      meta: { requiresAuth: false },
    },
    remote: { module: 'app2/app' }
  }
];

在路由器文件中,我们使用清单创建所有路由。这是因为导航到页面时,我们需要知道要加载哪个远程 MFE 并进行渲染。

所有 MFE 路由都指向 loader.vue,因为这里包含了处理 MFE 安装和卸载的大部分逻辑。它也确保每个 MFE 只有一个 Vue 实例(总共两个实例,包括主应用)。

// router/index.js
import { createRouter, createWebHistory } from 'vue-router';
import routeManifest from '../routeManifest';

const getRoutes = () => {
  return routeManifest.map((mfe) => ({
    path: mfe.route.path,
    name: mfe.route.name,
    meta: mfe.route.meta,
    component: () => import('@/components/loader.vue'), // 所有路由都指向 loader.vue
  }));
};

const routes = getRoutes();

const router = createRouter({
  history: createWebHistory(),
  routes,
});

export default router;

加载器组件 所有路由都指向 loader.vue,而不是直接渲染微前端。当访问路由时,该组件会动态加载并安装微前端,并在运行时使用 Module Federation 从远程主机获取 MFE。

loader.vue 中,我们跟踪当前路由。通过了解路由,我们可以确定要加载哪个远程 MFE。此外,我们跟踪当前已安装的 MFE,以便在加载新的 MFE 之前可以卸载它。此方法确保没有不必要的 Vue 实例正在运行。



结论 本文提供了一个简单的解决方案。当然,还有其他用例,例如从主应用处理 MFE 中的嵌套子路径,我们可以在后续文章中探讨。

通过实现路由清单和加载器组件,此微前端架构可以实现高度动态和可扩展的系统。使用 Vue 3、Vite 和 Module Federation,我们可以按需动态加载微前端,确保模块化和可维护性,同时保持良好的性能。 请访问完整的 GitHub 仓库了解更多信息并进行实验!

相关专题

更多
github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

357

2026.01.21

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

119

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

179

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

63

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

64

2026.01.22

热门下载

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

精品课程

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

共42课时 | 7.1万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

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

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