美文网首页
Router界面切换(四)导航守卫(导航控制)

Router界面切换(四)导航守卫(导航控制)

作者: fanren | 来源:发表于2021-02-27 10:59 被阅读0次

前言

导航守卫主要用来通过跳转或取消的方式守卫导航。

使用router进行界面切换,我们可以通过守卫导航正在切换的界面(从哪儿来,到哪儿去),并且可以控制是否跳转或者重定向;

一、全局守卫

  • 界面切换之前调用
router.beforeEach((to, from, next) => {
  next()
})
  • 界面切换之后调用
router.afterEach((to, from) => {
})

参数解析:

  • from:正要离开的界面
  • to:将要进入的界面
  • next: 是一个函数,控制是否导航是否继续调整;

二、路由独享的守卫

可以直接在路由配置上定义导航守卫

export default new Router({
  routes: [
    ......
    {
      path: '/first',
      name: 'first',
      component: first,
      beforeEnter: (to, from, next) => {
        // 导航切换到first界面时,调用
        next()
      },
    },
  ]
})

三、组件内的守卫

可以再组件内部直接定义导航守卫;

  • 组件显示之前调用
export default {
  name: "first",
  beforeRouteEnter(to, from, next) {
    // 此处组件的实例还未被创建,不能使用'this'
    next();
  },
};

beforeRouteEnter使用this

beforeRouteEnter(to, from, next) {
    next(vm => {
      // 通过 `vm` 访问组件实例
      // 在这里,组件的create方法已经被调用过了
    })
  },
  • 组件将要消失之前调用
export default {
  name: "first",
  beforeRouteLeave(to, from, next) {
    console.log("beforeRouteLeave");
    next();
  }
};

相关文章

  • Router界面切换(四)导航守卫(导航控制)

    前言 导航守卫主要用来通过跳转或取消的方式守卫导航。 使用router进行界面切换,我们可以通过守卫导航正在切换的...

  • vue导航守卫

    导航守卫:vue-router主要提供跳转或取消的方式守卫导航, 导航守卫分为全局前置守卫、全局解析守卫、全局后置...

  • vue-router进阶

    导航守卫 vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航(路由发生改变才会守卫)。参数 ...

  • 导航守卫

    vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航 全局守卫 全局前置守卫 当一个导航触发时...

  • vue-router导航守卫&&滚动&&路由懒加载

    导航守卫 正如其名,vue-router提供的导航守卫主要用来通过跳转或取消的方式守卫,有多种机会植入路由导航过程...

  • web前端面试题@九(vue导航守卫)

    什么是导航守卫? 正如其名,vue-router提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入...

  • vue中的路由的那些事

    一、导航守卫 1、全局守卫router.beforeEach router.beforeEach 很常用,比如验证...

  • 导航守卫以及keep-alive

    一 什么是导航守卫? vue-router提供的导航守卫主要用来监听监听路由的进入和离开的.vue-router提...

  • Vue2.0系列(八)vue-router高阶

    一、导航守卫 1.1、全局守卫 router.beforeEach 注册一个全局前置守卫: 当一个导航触发时,全局...

  • vue-router进阶

    导航守卫 vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。参数或查询的改变并不会触发进入...

网友评论

      本文标题:Router界面切换(四)导航守卫(导航控制)

      本文链接:https://www.haomeiwen.com/subject/quwmfltx.html