微前端: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应用已经加载出来了

相关推荐
一个处女座的程序猿O(∩_∩)O1 小时前
小型 Vue 项目,该不该用 Pinia 、Vuex呢?
前端·javascript·vue.js
hackeroink4 小时前
【2024版】最新推荐好用的XSS漏洞扫描利用工具_xss扫描工具
前端·xss
迷雾漫步者5 小时前
Flutter组件————FloatingActionButton
前端·flutter·dart
向前看-6 小时前
验证码机制
前端·后端
燃先生._.7 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js
高山我梦口香糖8 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
m0_748235248 小时前
前端实现获取后端返回的文件流并下载
前端·状态模式
m0_748240259 小时前
前端如何检测用户登录状态是否过期
前端
black^sugar9 小时前
纯前端实现更新检测
开发语言·前端·javascript