微前端:quankun

零: 前言

typescript 复制代码
微前端可以将大应用拆分功能独立的微应用,可独立开发部署,
每个微应用可以采用自己的技术栈,这样更好维护和拓展。

微前端也会存在跨域 权限控制 数据共享 性能(页面加载时间) 安全 
多团队协作(一个团队负责一个页面或模块) 组件重用。要采用适合的方案

一: 创建项目

主项目

typescript 复制代码
yarn create vite main-app --template react-ts

micro-react01项目

typescript 复制代码
npx create-react-app micro-react01 --template typescript

micro-vue01项目

typescript 复制代码
yarn create vite micro-vue01 --template vue-ts

二: 主项目操作

typescript 复制代码
npm i quankun -S

在主项目app.tsx加入下面的代码

typescript 复制代码
import { registerMicroApps, start } from 'qiankun';

registerMicroApps([
  {
    name: 'reactapp', // app name registered
    entry: '//localhost:3001',
    container: '#yourContainer1',
    activeRule: '/app1',
  },
  {
    name: 'vueapp',
    entry: '//localhost:5175',
    container: '#yourContainer2',
    activeRule: '/app2',
  },
]);

start();

import { loadMicroApp } from 'qiankun';

// loadMicroApp({
//   name: 'reactapp',
//   entry: '//localhost:3001',
//   container: '#yourContainer1',
// });

帮加上插槽地址

typescript 复制代码
<div id='yourContainer1'></div>
        <div id='yourContainer2'></div>

最终如下

app.tsx

typescript 复制代码
import { useState } from 'react'
import reactLogo from './assets/react.svg'
import viteLogo from '/vite.svg'
import './App.css'
import { registerMicroApps, start } from 'qiankun';

registerMicroApps([
  {
    name: 'reactapp', // app name registered
    entry: '//localhost:3001',
    container: '#yourContainer1',
    activeRule: '/app1',
  },
  {
    name: 'vueapp',
    entry: '//localhost:5175',
    container: '#yourContainer2',
    activeRule: '/app2',
  },
]);

start();

import { loadMicroApp } from 'qiankun';

// loadMicroApp({
//   name: 'reactapp',
//   entry: '//localhost:3001',
//   container: '#yourContainer1',
// });

function App() {
  const [count, setCount] = useState(0)

  return (
    <>
      <div>
        mainapp
        <div id='yourContainer1'></div>
        <div id='yourContainer2'></div>
      </div>
    </>
  )
}

export default App

三: 微项目操作

micro-react01项目

typescript 复制代码
在package.json中加入
  "devServer": {
    "headers": {
      "Access-Control-Allow-Origin": "*",
      "Access-Control-Allow-Methods": "GET, POST, PUT, DELETE",
      "Access-Control-Allow-Headers": "*"
    }
  }
  执行npm run build打包

然后启动服务

typescript 复制代码
npm i serve -g
serve

得到服务地址localhost:3001

四: 访问微应用

访问: 主项目地址/app1,

此时,发现micro-react01应用已经加载出来了

相关推荐
万少9 分钟前
我把 Kimi 接进微信,几分钟做了个随手出图助手
前端
xiaofeichaichai26 分钟前
网络请求与实时通道
前端·网络
kTR2hD1qb41 分钟前
从 Responses API 到 Chat Completions:一个模型网关的设计复盘
linux·前端
kyriewen2 小时前
浏览器缓存最强攻略:强缓存、协商缓存、CDN、更新策略,一篇搞定
前端·面试·浏览器
持敬chijing3 小时前
Web渗透之SQL注入-联合查询注入-注入点数据类型判断
前端·sql·安全·web安全·网络安全·安全威胁分析
卷帘依旧3 小时前
Web3前端一面
前端
古韵3 小时前
告别手写分页逻辑:usePagination 从 50 行到 3 行
java·前端
小村儿3 小时前
连载12- Cluade code 的MCP 到底还用不用
前端·后端·ai编程
IT_陈寒3 小时前
Vite静态资源引用差点把我逼疯,原来要这样处理
前端·人工智能·后端
子兮曰3 小时前
WSL 配 GPU 用 Docker 的折腾指南(2026 年版)
linux·前端·后端