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

发布于 2022-09-13 01:12:55 字数 687 浏览 17 评论 0

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里面也能监听到导航守卫。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

尐籹人 2022-09-20 01:12:55

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文