美文网首页
Vue路由守卫

Vue路由守卫

作者: _hider | 来源:发表于2019-11-07 17:37 被阅读0次

一、全局路由守卫

全局路由前置守卫

当用Vue开发的时候,如果项目涉及登录的话,一般都要做登录验证。用户必须先登录,拿到token才可以访问页面。因为路由是暴露的,用户可以通过修改URL来修改路由直接跳过登录验证。路由守卫就是解决以上问题的。看下以下代码:

import Vue from 'vue'
import Router from 'vue-router'
import Home from './views/Home.vue'
import Login from './views/Login.vue'

Vue.use(Router)

const vueRouter = new Router({
    routes: [
        {
            path: '/',
            name: 'Home',
            component: Home,
            meta: {
                needLogin: true
            }
        },
        {
            path: '/Login',
            name: 'Login',
            component: Login,
            meta: {
                needLogin: false
            }
        }
    ]
})

vueRouter.beforeEach((to, from, next) => {
    if (to.meta.needLogin && !sessionStorage.getItem('TOKEN')) {
        next({
            path: '/Login'
        })
    } else {
        next()
    }
})

export default vueRouter;

上面的有配置的路由表,beforeEach表示每次路由进入之前要执行的方法。metaneedLogin表示该网页是否需要登录验证,如果为true则跳过登录验证。登录完之后TOKEN会被保存在sessionStorage中,所以可以根据sessionStorage中是否有值来判断是否有登录,如果没TOKEN返回登录页。路由守卫接收三个参数:

beforeEnter(to,from,next)
to://即将要进入的目标路由对象
from://当前导航正要离开的路由
next://执行下一步

next()//直接进to 所指路由
next(false) //中断当前路由
next('route') //跳转指定路由
next('error') //跳转错误路由
全局路由后置守卫

全局路由后置守卫用到的地方倒不是很多,我一般目前用到的也就是埋点。afterEachbeforeEach钩子的参数类似,就是afterEach没有next方法。

vueRouter.afterEach((to, from) => {
    // ...
})

二、路由独享守卫

当全局的守卫不能满足某个页面的要求时,这个时候就需要用到独享守卫。用法与全局守卫一致。只是,将其写进其中一个路由对象中,只在这个路由下起作用。

{
    path: '/about',
    name: 'about',
    component: () => import('./views/About.vue'),
    beforeEnter(to, from, next) {
        to.query.returnURL = from.path;
        next();
    }
}

三、组件内守卫

beforeRouteEnter 是组件内的路由导航守卫,在确认渲染该组件的对应路由前调用。该守卫不能访问 this,但我们通过传一个回调给 next,就可以使用下例的 vm 来访问组件实例。

// 组件内的路由导航守卫
beforeRouteEnter(to, from, next) {
    // 路由的名称,对应路由配置中的 name
    const fromName = from.name;
    // 确认导航
    next(vm => {
        // 通过 vm 参数访问组件实例,已登录时,评估路由名称
        if (vm.$store.state.auth) {
            switch (fromName) {
                // 如果从注册页面跳转过来
                case "Register":
                    // 显示注册成功
                    vm.showMsg("注册成功");
                    break;
            }
        }
    });
}

相关文章

  • 华云

    一,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/pydumctx.html