IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 微前端-qiankun配置 -> 正文阅读

[JavaScript知识库]微前端-qiankun配置

基座配置

1.添加一个跳转到子应用的 router-link 的标签,也可以使用 qiankun 跳转方法去跳转页面

2.需要给你的子项目添加挂载的容器, 比如我把 vue 子项目 挂载到

3.给基座(父级项目)安装 qiankun 依赖:yarn add qiankun -S

4.在 main.js 中引入 qiankun: import { registerMicroApps, start } from “qiankun”;

5.定义 子应用 数组 数据

import { registerMicroApps, start } from "qiankun";

const apps = [
  {
    name: "vueApp", // 应用名称
    entry: "//localhost:10000", // 加载这个html文件
    container: "#vue", // 子应用挂载到基座的容器
    activeRule: "/vue", // 激活路径
    props: {
      a: 1,
    },
  },
  {
    name: "reactApp",
    entry: "//localhost:20000",
    container: "#react",
    activeRule: "/react",
  },
];

registerMicroApps(apps); // 注册应用
start(); // 开启

Vue 项目配置

1.router 文件修改 base: ‘/vue’

2. 在 main.js 中 必须导出三个方法

let instance = null; // 用于保存实例, 方便卸载子应用

function render(props) {
  instance = new Vue({
    router,
    render: (h) => h(App),
  }).$mount("#app"); // 子应用还是挂载到自己的容器上 基座会拿到挂载后的html文件,然后插入进去
}

//  确保子应用可以正常独立运行
if (!window.__POWERED_BY_QIANKUN__) {
  render();
}

// 如果子应用和基座项目的访问ip不同,qiankun可以动态的改变子应用的ip
if (window.__POWERED_BY_QIANKUN__) {
  __webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}

// 子组件协议 (协议其实就是基座和子应用进行沟通的规则,在这里就是子应用必须导出这三个方法)
export async function bootstrap(props) {
  console.log(props.a); // 1
  // 启动
}

export async function mount(props) {
  // 挂载
  render(props);
}

export async function unmount(props) {
  // 卸载
  instance.$destroy();
}

3.配置 vue.config.js 使其子项目导出一个 lib 库

module.exports = {
  configureWebpack: {
    output: {
      library: "vueApp", // 库名
      libraryTarget: "umd", // js规范
    },
    devServer: {
      port: 10000, // 开发环境启动端口号
      headers: {
        // 开发环境允许跨域
        "Access-Control-Allow-Origin": "*",
      },
    },
  },
};

react 项目配置

1.因为需要写一些 webpack 的配置,所以需要安装一个插件:yarn add react-app-rewired -D

1.1 需要更改一下命令(start\build 都需要改一下):react-app-rewired start、:react-app-rewired build

2. 和 Vue 项目一样,先导出三个方法,如下:

3. 封装一个 render 函数

4. 需要在 unmount 中卸载应用

5. 让本地环境可以正常运行需要添加开发环境的 render 函数的执行

6. 如果子应用和基座项目的访问 ip 不同,qiankun 可以动态的改变子应用的 ip

//  5. 让本地环境可以正常运行需要添加开发环境的render函数的执行
if (!window.__POWERED_BY_QIANKUN__) {
  render();
}

// 6. 如果子应用和基座项目的访问ip不同,qiankun可以动态的改变子应用的ip
if (window.__POWERED_BY_QIANKUN__) {
  __webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}

// 3. 封装一个 render 函数
function render() {
  ReactDOM.render(
    <React.StrictMode>
      <App />
    </React.StrictMode>,
    document.getElementById("root")
  );
}

// 2.导出下面这三个方法
export async function bootstrap(props) {
  console.log(props.a); // 1
  // 启动
}

export async function mount(props) {
  // 挂载
  render(props);
}

export async function unmount(props) {
  // 4. 卸载
  ReactDOM.unmountComponentAtNode(document.getElementById("root"));
}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-06 16:08:57  更:2022-04-06 16:10:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:30:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码