qiankun:vue3+webpack 微前端搭建

主应用

1.安装乾坤

js 复制代码
npm install qiankun 或 yarn add qiankun

2.设置微应用容器文件或容器节点

js 复制代码
<div id="micros"></div>

3.设置子应用列表引入registerMicoApps方法注册子应用

js 复制代码
import { registerMicroApps, setDefaultMountApp } from "qiankun";
js 复制代码
 registerMicroApps(
    [
      {
        name: "technicalservice", //子应用名称
        entry: process.env.VUE_APP_MICROS_PATH, //加载子应用路径
        container: "#micros", //容器主节点
        activeRule: "/micros", //加载微应用的路径,(当我们访问的路由路径以配置内容开头时,自动访问微应用)
        props: {},    //向微应用传递数据
      },
    ])

4.在项目入口文件main.js

js 复制代码
import { start } from "qiankun";
start();

注:如果是本地调试记得设置跨域,在vue.config.js中的server中

js 复制代码
      headers: {
      "Access-Control-Allow-Origin": "*",
    },

子应用

1.子应用中无需安装qiankun在入口文件中设置render函数,导出生命周期钩子函数

js 复制代码
export async function bootstrap() {
  console.log("technicalservice bootstrap");
  // 你的启动逻辑(可选)
}

export async function mount(props) {
  console.log("technicalservice mount", props);
  const { container } = props;
  render(container);
  // 你的挂载逻辑(比如将应用渲染到某个DOM元素中)
}

export async function unmount() {
  console.log("technicalservice unmount");
  // 你的卸载逻辑(比如清理或从DOM中移除应用)
}

let app = null;
const render = (container) => {
  app = createApp(App);
  const getIcons = (requireContext) =>
    requireContext.keys().map(requireContext);
  //   如果是在主应用下就挂载主应用的节点,否则挂载在本地
  const appDom = container ? container.querySelector("#ccbn-son") : "#ccbn-son";
  getIcons(require.context("./assets/icon", false, /\.svg$/));
  app.component("Icon", icon);
  const pinia = createPinia();
  app.use(pinia).use(router).use(Antd).use(Print).mount(appDom);
};

// 独立运行
if (!window.__POWERED_BY_QIANKUN__) {
  console.log("独立运行");
  render(null);
}

2.添加pulic-path.js文件,在main.js中引入

js 复制代码
if (window.__POWERED_BY_QIANKUN__) {
  __webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}

如果这段代码报错,在webpack配置中添加

js 复制代码
   "globals": {
      "__webpack_public_path__": true
    }

3.配置微前端打包工具,否则挂载微前端时会报错找不到子应用导出生命周期函数

js 复制代码
  configureWebpack:{
    output:{
      library:`${name}-[name]`,
      libraryTarget:"umd",
    }
  },
相关推荐
wearegogog1237 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
Drawing stars7 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
品克缤7 小时前
Element UI MessageBox 增加第三个按钮(DOM Hack 方案)
前端·javascript·vue.js
小二·8 小时前
Python Web 开发进阶实战:性能压测与调优 —— Locust + Prometheus + Grafana 构建高并发可观测系统
前端·python·prometheus
小沐°8 小时前
vue-设置不同环境的打包和运行
前端·javascript·vue.js
Irene19918 小时前
Vue3 <Suspense> 使用指南与注意事项
vue.js·suspense
qq_419854058 小时前
CSS动效
前端·javascript·css
烛阴8 小时前
3D字体TextGeometry
前端·webgl·three.js
桜吹雪9 小时前
markstream-vue实战踩坑笔记
前端
C_心欲无痕9 小时前
nginx - 实现域名跳转的几种方式
运维·前端·nginx