VUE路由守卫

作者: level | 来源:发表于2019-03-13 18:05 被阅读12次

login.vue

//其他逻辑页面代码省略
//登录成功本地存储登录名称,在退出时请清空
localStorage.setItem('name', '1111');
//登录成功后跳转
this.$router.replace({ name: index}});

router/index.js

import Vue from 'vue';
import VueRouter from 'vue-router';

const index             = resolve => require(['@/pages/index.vue'], resolve);
const login             = resolve => require(['@/pages/login.vue'], resolve);

Vue.use(VueRouter);

/**
 * @method 路由配置
 */
const router = new VueRouter({
  mode: 'hash',
  routes: [
    {
      path: '/',
      name: 'index',
      component: login,
      meta: {
        login_auth: true
      }
    },
    {
        path: '/login',
        name: 'login',
        component: login,
        meta: {
          login_auth: false
        }
    }
    // ...
  ]
});

/**
 * @method 全局前置守卫
 * @param {参数类型} 参数名 参数说明
 *  {
 *      to: 将要跳转到的路由,
 *      from: 将要离开的路由,
 *      next: 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是confirmed (确认的)
 *  }
 */
router.beforeEach((to, from, next) => {
  // 判断该路由是否需要登录权限
  if (to.meta.login_auth) {
    // 根据是否注册用户名,判断是否登录,未登录太转到登录页面
    if(!localStorage.getItem('name')){
      if(to.name != 'login') {
        next('/login');
      }else{
        //必须调用 next 方法,否则钩子就不会被 resolved;因为next('/login')就是路由跳转,会再次触发路由守卫所以或造成死循环。
        next();
      }

      return;
    }
  }
  //必须调用 next 方法,否则钩子就不会被 resolved
  next();
});

export default router;

需要注意

1、next() 会直接进入to路由,不会再调用router.beforeEach();
2、next('/login')当前导航中断, 跳转到login,会再次调用router.beforeEach(),所以必须调用next(),否则会造成死循环.

相关文章

  • 华云

    一,vue路由守卫的生命周期1,全局的前置路由守卫 router.beforeEach()2, 全局解析守卫 ...

  • react实现路由守卫

    与vue不同,vue直接使用beforeEach即可实现全局路由守卫等功能。react要实现路由守卫得自己配置。实...

  • vue-router 常见导航守卫

    全局守卫vue-router全局有三个守卫 路由独享守卫如果你不想全局配置守卫的话,你可以为某些路由单独配置守卫 ...

  • vue 路由导航白话全解析

    这里先放上官网的教程和说明:点击这里,vue导航守卫官方文档 路由守卫 路由守卫说白了就是路由拦截,在地址栏跳转之...

  • Vue导航守卫

    Vue导航守卫 理解 导航守卫也叫路由守卫,可以实时的监控路由的跳转过程,在路由的跳转的各个过程执行相应的操作,有...

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • 关于vue路由守卫做登陆状态判断的问题

    关于vue路由守卫做登陆状态判断的问题 直接上代码 // 全局路由守卫 router.beforeEach((to...

  • Vue路由/路由守卫

    一、前端路由和后端路由概念解释 二、路由的基本使用方式 三、常见引入路由组件的方式和区别 四、常见引入路由分类1....

  • Vue - 路由守卫(路由的生命周期)

    路由守卫是什么? 官方解释:“导航”表示路由正在发生改变。正如其名,vue-router提供的导航守卫主要用来通过...

  • vue-router进阶

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

网友评论

    本文标题:VUE路由守卫

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