vue3.0 + qiankun遇到的问题

进入子应用再回到主应用切换动态路由时

TypeError: Cannot read properties of undefined (reading 'appWrapperGetter')

application 'plat' died in status UNMOUNTING: instance.$destroy is not a function

第一个报错是因为子应用切走时没有销毁 vue的实例,在qiankun的 unmount 生命周期中,销毁 vue的实例即可!

这就引出了第二个报错,这个意思是实例中 没有 d e s t r o y 方法, destroy方法, destroy方法,destroy是vue2.0中销毁实例的方法,在vue3.0中,销毁实例用 unmount方法。代码是:

复制代码
/** 正确写法 */
let instance = null;
function render(props = {}) {
  const { container } = props;
  instance = createApp(App); // 这样才是创建了vue实例,此后才是往vue实例上挂载三方插件
  instance.use(router).use(store).mount(container ? container.querySelector("#app") : "#app");
}
export async function unmount(props) {
  instance.unmount(); // 销毁实例 vue3命名为unmounted vue2命名为destroyed
}

理论上上面的代码按说是可以的,但是如果我们qiankun的基座是vue2.0,在这里其实还是会报错,这里拿到的instance打印发现是这样的:

正确的写法是这样:

复制代码
let instance: any = null;
function render (props: any = {}) {
  const { container } = props;
  instance = createApp(App);
  instance.use(store)
    .use(router)
    .use(ElementPlus, { locale: zhCn })
    .mount(container ? container.querySelector('#app') : '#app');
  console.log(instance);
}
export async function bootstrap () {
  // console.log('[vue] vue app bootstraped');
}
export async function mount (props: any) {
  render(props);
}
export async function unmount () {
  if (instance) {
    instance.unmount();
    instance = null;
  }
}

打印是这个:

到这里问题就算解决了

相关推荐
LaughingZhu43 分钟前
Product Hunt 每日热榜 | 2026-04-05
前端·数据库·人工智能·经验分享·神经网络
SuperEugene1 小时前
Vue3 组件复用设计:Props / 插槽 / 组合式函数,三种复用方式选型|组件化设计基础篇
前端·javascript·vue.js
nFBD29OFC2 小时前
利用Vue元素指令自动合并tailwind类名
前端·javascript·vue.js
ISkp3V8b42 小时前
ASP.NET MVC]Contact Manager开发之旅之迭代2 - 修改样式,美化应用
前端·chrome
Highcharts.js3 小时前
高级可视化图表的暗色模式与主题|Highcharts 自适应主题配色全解
前端·react.js·实时图表
i220818 Faiz Ul3 小时前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
zk_one4 小时前
【无标题】
开发语言·前端·javascript
AIBox3655 小时前
openclaw api 配置排查与接入指南:网关启动、配置文件和模型接入全流程
javascript·人工智能·gpt
precious。。。5 小时前
1.2.1 三角不等式演示
前端·javascript·html
阿珊和她的猫5 小时前
TypeScript 中的 `extends` 条件类型:定义与应用
javascript·typescript·状态模式