全网 最保姆级的微前端 无界教程

狗头保命,我是标题党

微前端

概念

本质上就是将每个将产品中的各个功能模块作为一个个独立的应用系统,然后将这些模块再整合起来组装成完整的产品。而像无界或者乾坤这些框架提供的功能就是:本质上都是为了将复杂庞大的前端应用拆解成一个个可以独立开发的部署的功能模块,并通过暴露相关的接口和功能来将各个功能模块进行连接。

相关API

preloadApp

预执行指的是在应用空闲的时候将子应用提前渲染出来,可以进一步提升子应用打开时间

只需要在preloadApp中将 exec 设置为true即可

如何理解无界的生命周期这一块,对比vue生命周期,类似,就是你希望在什么周期去触发什么行为

定义相关子应用

javascript 复制代码
const appList = [
{
    name: 应用名,// 比如你的子应用名为mrcor-vue2,那么这个name有什么用处,下面会说到
    url:子应用url,// 当你匹配到url的时候,就会去加载这个子应用,比如你的子应用的url单独跑的时候,https://localhost:3001
    props:  默认接受window数据的方式,
    alive: true, // 子应用是否激活
    beforeLoad: function(){}, // 生命周期,
    beforeMount: function(){} // 具体看无界文档关于生命周期这一块
}
]

注册子应用

setupApp,这个方法呢,好比vue.use()去注册相关方法

javascript 复制代码
// 我们刚刚上面注册了appList,那么要怎么去注册相关子应用呢?聪明的你,一定想到了方法
appList.forEach(item=>{
    setupApp(item) // 这样就实现了子应用的注册
    // 但是如果你想着说你这个是要提前加载,然后当我们去打开子应用的时候,就可以加快加载出来,那么这个api方法就方法发挥着优势
    preloadApp({
      name: xxx, // 必传
      url: xxx, // 必创,
      exex: true
    })
    
})

注册路由

arduino 复制代码
注册路由,其他的正常写
const routes = [
    path: '/vue2' , // 这个path就是你子应用注册的路由
    appName: vue2 // 这个对应的就是应用名
]

通信

1:props

2:发布订阅

这两种是最常见的通信方式

php 复制代码
props方式
定义一个容器,然后props传递

<WujieVue name="xxx" url="xxx" :props="{ data: xxx, methods: xxx }"></WujieVue>

子应用接收
const props = window.$wujie?.props; // {data: xxx, methods: xxx}

订阅与发布

// 如果使用wujie
import { bus } from "wujie";

// 如果使用wujie-vue
import WujieVue from "wujie-vue";
const { bus } = WujieVue;

// 如果使用wujie-react
import WujieReact from "wujie-react";
const { bus } = WujieReact;

// 主应用监听事件
bus.$on("事件名字", function (arg1, arg2, ...) {});
// 主应用发送事件
bus.$emit("事件名字", arg1, arg2, ...);
// 主应用取消事件监听
bus.$off("事件名字", function (arg1, arg2, ...) {});

// 子应用监听事件
window.$wujie?.bus.$on("事件名字", function (arg1, arg2, ...) {});
// 子应用发送事件
window.$wujie?.bus.$emit("事件名字", arg1, arg2, ...);
// 子应用取消事件监听
window.$wujie?.bus.$off("事件名字", function (arg1, arg2, ...) {});

路由跳转

路由跳转,本质上还是要用vue-router 提供的方法 但是如果你是A应用跳转到B应用,你可以选择基座提供的Props的跳转方法,或者你用eventbus这种通信方式,本质上就是利用 通信方式 + vue的路由跳转方法 props方式

xml 复制代码
<template>
  <!-- 子应用 A -->
  <wujie-vue name="A" url="//hostA.com" :props="{jump}" ></WujieVue>
</template>

<script>
export default {
  methods: {
    jump(location) {
      this.$router.push(location);
    }
}
</script>
// 子应用 A 点击跳转处理函数
function handleJump() {
  window.$wujie?.props.jump({ path: "/pathB" });
}

event-bus方式

javascript 复制代码
// 子应用 A 点击跳转处理函数
function handleJump() {
  window.$wujie?.bus.$emit("routeChange", "/test");
}
// 子应用 B 监听并跳转
window.$wujie?.bus.$on("routeChange", (path) => this.$router.push({ path }));
相关推荐
漂流瓶jz20 小时前
解锁Babel核心功能:从转义语法到插件开发
前端·javascript·typescript
周小码21 小时前
shadcn-table:构建高性能服务端表格的终极解决方案 | 2025最新实践
前端·react.js
大怪v21 小时前
老乡,别走!Javascript隐藏功能你知道吗?
前端·javascript·代码规范
webYin1 天前
vue2 打包生成的js文件过大优化
前端·vue.js·webpack
gnip1 天前
结合Worker通知应用更新
前端·javascript
叶玳言1 天前
【LVGL】从HTML到LVGL:嵌入式UI的设计迁移与落地实践
前端·ui·html·移植
高级测试工程师欧阳1 天前
HTML 基本结构
前端
Gazer_S1 天前
【Element Plus 表单组件样式统一 & CSS 文字特效实现指南】
前端·css·vue.js
一只小阿乐1 天前
Html重绘和重排
前端·html
_Rookie._1 天前
vue3 使用css变量
前端·javascript·html