qiankun 路由选择不同模式如何书写不同的配置

qiankun 路由选择不同模式如何书写不同的配置

首先,我们了解一下qiankun中如何命中子应用的,假设主应用使用history,子应用也是用history模式,activeRule 的规则为**/sub-app**,当浏览器地址栏输入http://localhost:8080/sub-app/index 时,则命中规则;反之http://localhost:8080/#/sub-app/index 或者 http://localhost:8080/#/child/sub-app/index ,都不会命中规则。

下面介绍一下不同情况的路由模式该如何配置

1.当主应用和子应用都使用history模式时(最简单,推荐)

重点是base 需和主应用的activeRule保持一致

js 复制代码
// 主应用
import { start, registerMicroApps } from "qiankun"

registerMicroApps([
  {
    name: 'app1',
    entry: '//localhost:8081',
    container: '#container',
    activeRule: '/app1',
    props: {}
  }
])

start()

子应用vue3,重点是createWebHistory(routerBase)

js 复制代码
// 子应用 router/index.js
const routerBase = window.__POWERED_BY_QIANKUN__ ? '/app1' : '/'
const router = createRouter({
  history: createWebHistory(routerBase),
  routes
})

子应用vue2

js 复制代码
// 子应用router/index.js
const routerBase = window.__POWERED_BY_QIANKUN__ ? '/app1' : '/'
const router = new VueRouter({
  base: routerBase,
  routes,
  mode: 'history'
})

2.主应用和子应用都使用hash模式

注意hash模式,主应用activeRule需要加上**"#"**

js 复制代码
// 主应用
import { start, registerMicroApps } from "qiankun"

registerMicroApps([
  {
    name: 'app1',
    entry: '//localhost:8081',
    container: '#container',
    activeRule: '#/app1',
    props: {}
  }
])

start()

而子应用有两种方式:

  • 给所有路由加上前缀,前缀需要和activeRule保持一致,即/app1

  • 创建一个空路由,将其他路由全部放入该路由的children中,例如

    js 复制代码
    const routes = [
      {
        path: "/app1",
        component: HomeView,
        children: [
          {
            path: "home",
            name: "home",
            component: HomeView,
          },
          {
            path: "about",
            name: "about",
            component: () =>
              import(/* webpackChunkName: "about" */ "../views/AboutView.vue"),
          },
        ],
      },
    ];

关于router base和publicPath的作用,请看这篇文章Vue中路由router的base配置与vue.config.js的publicPath配置的区别

相关推荐
共享家95275 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
Halo_tjn6 小时前
基于封装的专项 知识点
java·前端·python·算法
有来技术7 小时前
Spring Boot 4 + Vue3 企业级多租户 SaaS:从共享 Schema 架构到商业化套餐设计
java·vue.js·spring boot·后端
东东5169 小时前
学院个人信息管理系统 (springboot+vue)
vue.js·spring boot·后端·个人开发·毕设
m0_748229999 小时前
Vue2 vs Vue3:核心差异全解析
前端·javascript·vue.js
C澒9 小时前
前端监控系统的最佳实践
前端·安全·运维开发
xiaoxue..9 小时前
React 手写实现的 KeepAlive 组件
前端·javascript·react.js·面试
hhy_smile9 小时前
Class in Python
java·前端·python
小邓吖10 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang
南风知我意95710 小时前
【前端面试2】基础面试(杂项)
前端·面试·职场和发展