基于 qiankun + vite + vue3 构建微前端应用实践

核心内容摘要​​

  1. ​​技术栈组合​​
    • 采用 Vite + Vue3 + Qiankun 构建微前端架构
    • 主应用和子应用独立开发部署,通过 Qiankun 集成
      ​​2. 主应用关键配置​​
    • 通过 registerMicroApps 注册子应用,配置路由匹配规则(activeRule
    • 使用 start() 启动微前端框架
    • 动态容器设计:子应用挂载到主应用的 #sub-container 节点
      ​​3. 子应用特殊处理​​
    • 使用 vite-plugin-qiankun 插件简化集成
    • 动态路由适配:根据是否在 Qiankun 环境切换路由基础路径
    • 生命周期管理:通过 renderWithQiankun 暴露挂载/卸载钩子
    • 必须配置 UMD 格式打包和跨域支持
  2. ​​开发环境优化​​
    • 主应用代理子应用请求(解决端口问题)
    • 子应用需配置 base 路径和 CORS
  3. ​​生产环境要求​​
    • 静态资源部署到独立路径(如 /sub-app/
    • Nginx 需配置路径重写规则
    • 推荐预加载和依赖共享优化性能

介绍

Qiankun

qiankun 是一个基于 single-spa 的微前端实现库,旨在帮助大家能更简单、无痛的构建一个生产可用微前端架构系统。

微前端

微前端是一种多个团队通过独立发布功能的方式来共同构建现代化 web 应用的技术手段及方法策略。

微前端架构具备以下几个核心价值:

  • 技术栈无关

    主框架不限制接入应用的技术栈,微应用具备完全自主权

  • 独立开发、独立部署

    微应用仓库独立,前后端可独立开发,部署完成后主框架自动完成同步更新

  • 增量升级

    在面对各种复杂场景时,我们通常很难对一个已经存在的系统做全量的技术栈升级或重构,而微前端是一种非常好的实施渐进式重构的手段和策略

  • 独立运行时

    每个微应用之间状态隔离,运行时状态不共享

Code

基于 vite + vue3 + qiankun 构建一个微前端应用;创建一个文件夹 my-apps;

依赖版本:

  • node: >= 18
  • vue: 3.5.16
  • vite: 6.3.5
  • qiankun: 2.10.16
  • vue-router: 4.5.1

主应用

my-apps 下执行如下命令:

$ pnpm create vue   # 设置项目名称为 main-app
$ cd main-app
$ pnpm i

main-app 安装相关依赖:

$ pnpm i qiankun

App.vue

<template>
  <router-view></router-view>
</template>

router.js

要为子应用设置对应的匹配路径

import {
   
    createRouter, createWebHistory } from "vue-router";

const routes = [
  {
   
    path: "/", name: "home", component: () => import("../views/Home.vue") },
  {
   
    path: "/sub-app/:pathMatch(.*)*", name: "sub-app", component: () => import("../views/SubApp.vue") },
];

const router = createRouter({
   
   
  history: createWebHistory()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值