微前端架构:使用不同框架构建可扩展的大型应用

概述

在现代Web开发中,随着业务复杂度的不断提高,单一的巨型应用逐渐难以满足高效开发和维护的需求。微前端架构作为一种解决方案,允许将一个大型应用拆分成多个独立的小型应用,这些小型应用可以单独开发、部署,并且能够灵活地集成在一起形成一个完整的系统。这种模式提高了开发效率,降低了维护成本,并且可以支持多种前端框架共存。

微前端架构的优点

  1. 可扩展性:每个微前端都可以独立开发、部署,易于扩展。
  2. 灵活性:可以根据业务需求选择最合适的前端框架和技术栈。
  3. 隔离性:各个微前端之间相互隔离,降低了互相影响的风险。
  4. 可维护性:每个微前端都是一个小的、可管理的模块,更容易维护。

微前端架构的实现方式

qiankun

qiankun 是一个轻量级的微前端解决方案,它基于单页应用 (SPA) 的理念,使用代理的方式实现了子应用的加载和卸载。

示例:使用qiankun实现多框架微前端

假设我们有一个主应用(使用React),以及两个子应用(一个使用Vue,另一个使用Angular)。

1. 主应用(使用React)

安装依赖

bash

深色版本

复制代码
1npm install react react-dom @umijs/qiankun
创建主应用

jsx

深色版本

复制代码
1// src/index.js
2import React from 'react';
3import ReactDOM from 'react-dom';
4import { registerMicroApps, start } from 'qiankun';
5
6const container = document.getElementById('root');
7
8ReactDOM.render(
9  <div>
10    <h1>主应用 - React</h1>
11    <div id="sub-vue"></div>
12    <div id="sub-angular"></div>
13  </div>,
14  container
15);
16
17registerMicroApps([
18  {
19    name: 'sub-vue',
20    entry: '//localhost:8081',
21    container: '#sub-vue',
22    activeRule: '/sub-vue',
23  },
24  {
25    name: 'sub-angular',
26    entry: '//localhost:4200',
27    container: '#sub-angular',
28    activeRule: '/sub-angular',
29  },
30]);
31
32start();

2. Vue 子应用

安装依赖

bash

深色版本

复制代码
1npm install vue
创建Vue子应用

vue

深色版本

复制代码
1// src/main.js
2import Vue from 'vue';
3import App from './App.vue';
4
5new Vue({
6  render: h => h(App),
7}).$mount('#app');
8
9if (module.hot) {
10  module.hot.accept();
11}

html

深色版本

复制代码
1<!-- public/index.html -->
2<!DOCTYPE html>
3<html lang="en">
4<head>
5  <meta charset="UTF-8">
6  <meta name="viewport" content="width=device-width, initial-scale=1.0">
7  <title>Vue Sub Application</title>
8</head>
9<body>
10  <div id="app"></div>
11  <script src="/dist/runtime.js"></script>
12  <script src="/dist/polyfills.js"></script>
13  <script src="/dist/vendor.js"></script>
14  <script src="/dist/main.js"></script>
15</body>
16</html>
复制代码

vue

深色版本

复制代码
1<!-- src/App.vue -->
2<template>
3  <div>
4    <h1>子应用 - Vue</h1>
5  </div>
6</template>
7
8<script>
9export default {
10  name: 'App',
11};
12</script>

3. Angular 子应用

安装依赖

bash

深色版本

复制代码
1ng new angular-sub-app
2cd angular-sub-app
3ng build --prod
修改Angular子应用

typescript

深色版本

复制代码
1// src/app/app.component.ts
2import { Component } from '@angular/core';
3
4@Component({
5  selector: 'app-root',
6  template: `
7    <div>
8      <h1>子应用 - Angular</h1>
9    </div>
10  `,
11})
12export class AppComponent {}

4. 启动服务器

对于Vue和Angular子应用,你可以使用本地开发服务器启动它们。例如,Vue可以用vue-cli启动,Angular可以用ng serve启动。

5. 测试

在浏览器中访问主应用的地址(比如 http://localhost:3000/),然后导航到 /sub-vue/sub-angular,你会看到Vue和Angular子应用被正确加载和渲染。


以上是一个简单的示例,展示了如何使用qiankun实现基于不同前端框架的微前端架构。在实际项目中,你还需要考虑更多因素,比如状态管理、路由同步等问题。希望这个例子能够帮助你理解微前端的基本概念和实现方法。

以下是根据微前端架构下的主应用和两个子应用(一个Vue,一个Angular)设计的架构图:

此图展示了一个使用React作为主应用的场景,其中包含了两个子应用,分别是使用Vue和Angular构建的。主应用使用了qiankun来管理和调度子应用的加载与卸载。每个子应用都有自己的开发和构建流程,并且可以独立部署,最终通过主应用集成在一起。

希望这个架构图能够帮助你更好地理解微前端的工作原理和组件之间的交互方式。如果有任何疑问或需要进一步的帮助,请随时提问。

相关推荐
xixixi7777710 分钟前
CDN(内容分发网络)——缓存和分发网站、应用程序、视频等内容,以提高用户访问速度和稳定性,减少网络延迟和拥塞,同时减轻源服务器的压力
网络·缓存·架构·系统架构·cdn·业务·内容分发网络
sld16840 分钟前
打破云服务“绑定”局限,打造高适配性、强管控力的混合云架构新范式
微服务·云原生·架构
OEC小胖胖1 小时前
02|从 `createRoot` 到 `scheduleUpdateOnFiber`:一次更新如何进入 React 引擎
前端·javascript·react.js·前端框架
Xの哲學2 小时前
Linux 文件系统一致性: 从崩溃恢复到 Journaling 机制
linux·服务器·算法·架构·边缘计算
DencyCheng3 小时前
Nacos 的全面价值分析:从多角色视角到多架构场景的深度解析
微服务·架构
智源研究院官方账号3 小时前
众智FlagOS 1.6发布,以统一架构推动AI硬件、软件技术生态创新发展
数据库·人工智能·算法·架构·编辑器·硬件工程·开源软件
攀登的牵牛花3 小时前
前端向架构突围系列 - 架构方法(一):概述 4+1 视图模型
前端·设计模式·架构
Hashan3 小时前
Vue 3 中 v-for 动态组件 ref 收集失败问题排查与解决
前端·vue.js·前端框架
lhrimperial5 小时前
微服务架构深度解析-微服务理论基础(一)
微服务·架构·wpf
Tinachen886 小时前
YonBIP旗舰版本地开发环境搭建教程
java·开发语言·oracle·eclipse·前端框架