vue的qiankun子应用为什么hash路由跳转不成功
时间: 2024-01-08 14:04:24 浏览: 40
在使用 Qiankun 开发子应用时,如果子应用使用的是 hash 模式路由,需要在子应用的入口文件中,手动初始化路由。
在 Vue 的子应用中,可以在 `main.js` 文件中进行路由初始化,具体实现如下:
```
import Vue from 'vue'
import App from './App.vue'
import router from './router'
Vue.config.productionTip = false
// 手动初始化路由
let instance = null
function render(props = {}) {
const { container } = props
instance = new Vue({
router,
render: h => h(App)
}).$mount(container ? container.querySelector('#app') : '#app')
}
// 如果不是作为子应用使用,则直接渲染应用
if (!window.__POWERED_BY_QIANKUN__) {
render()
}
// 导出生命周期钩子函数
export async function bootstrap() {}
export async function mount(props) {
// 初始化路由
render(props)
}
export async function unmount() {
// 销毁实例
instance.$destroy()
instance = null
}
```
在这里,我们通过 `render` 函数手动初始化了路由,并在 `mount` 钩子中再次调用 `render` 函数,以保证子应用在挂载时能够正确初始化路由。
另外,需要注意的是,在切换子应用时,主应用会将当前的路由信息传递给子应用,因此,子应用需要在接收到这些信息后自行进行路由跳转。你可以通过监听 `qiankun` 的 `routeChange` 事件来实现这个功能,具体实现如下:
```
import Vue from 'vue'
import App from './App.vue'
import router from './router'
Vue.config.productionTip = false
// 手动初始化路由
let instance = null
function render(props = {}) {
const { container } = props
instance = new Vue({
router,
render: h => h(App)
}).$mount(container ? container.querySelector('#app') : '#app')
}
// 如果不是作为子应用使用,则直接渲染应用
if (!window.__POWERED_BY_QIANKUN__) {
render()
}
// 导出生命周期钩子函数
export async function bootstrap() {}
export async function mount(props) {
// 初始化路由
render(props)
// 监听 routeChange 事件
props.onGlobalStateChange((state, prev) => {
if (state.type === 'vue2_subapp_route_change') {
const { path } = state.payload
router.push(path)
}
})
}
export async function unmount() {
// 销毁实例
instance.$destroy()
instance = null
}
```
在这里,我们通过 `props.onGlobalStateChange` 监听 `routeChange` 事件,并在事件回调函数中跳转路由。当主应用切换路由时,会触发这个事件,从而实现路由跳转。