vue-router4.x中导航守卫在app.vue内无法触发?

app.vue代码如下:

<template>
  <router-view></router-view>
</template>

<script lang="ts">
import { defineComponent } from 'vue';
import { onBeforeRouteLeave } from 'vue-router';

export default defineComponent({
  name: 'App',
  setup() {
    onBeforeRouteLeave((to, from) => {
      console.log('onBeforeRouteLeave', to, from);
    });
  }
});
</script>

浏览器内会有这样一个警告,同时也没有监听到onBeforeRouteLeave
image.png

如果我放到页面里面去就可以监听到这个事件,但是同样也会有一个警告
image.png

请大佬指点一下如何消除这两个警告,并且在app.vue里面也能监听到导航守卫。

阅读 2.8k
1 个回答

原因大概是知道了,是因为我在app.vue下面使用onBeforeRouteLeave这个路由钩子,而app.vue是总路由的页面,所以不会触发这个路由钩子,就提示警告了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题