VueRouter类实例的应用和全局前置路由

该文章讲述了如何使用VueRouter的全局前置守卫beforeEach进行路由跳转控制,确保每次跳转时都有用户信息。如果检测到token,则会尝试获取用户信息,若token无效则执行登出并重定向至登录页面。否则,允许无token的访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、VueRouter类管理组件路由routes

 2、全局前置路由(to:去哪个路由,from:来自那个路由,next:实质是一个函数方法,一般直接调用【next('路由路径')、next()等】)注意:这里可以解决每次跳转路由用户数据丢失的情况,很重要!!

// 全局前置守卫

router.beforeEach(async (to, from, next) => {

    // 用户是否跳转,取决于仓库里面是否有token

    // 每一次路由跳转之前都需要有用户信息在跳转,没有就发请求获取用户信息在跳转

    let hasToken = store.state.user.token;

    // 用户信息

    let hasNickName = store.state.user.nickName;

    // 用户登录

    if (hasToken) {

        // 用户登录,不能去login

        if (to.path == '/login') {

            next('/home')

        } else {

            //用户登录了。而且还有用户信息

            if (hasNickName) {

                next()

            } else {

                //用户登录了。但是没有用户信息

                try {

                    // 发请求获取用户信息以后再放行

                    await store.dispatch('getUserInfo')

                    next()

                } catch (error) {

                    // token过期、失效,用户没有信息携带token发请求获取信息失败

                    await store.dispatch('logout')

                    next('/login')

                }

            }

        }

    } else {

        next()

    }

})

3、最后暴露出去

 4、文件分类

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值