vue 导航守卫

vue 导航守卫在这里插入图片描述
from:从哪来
to:到哪里去
next是一个函数决定是否放行 ,next()放行,next(’/login’)拦截到login
配置全局前置守卫,在router文件中进行配置
所有的路由在被真正访问之前,都会经过全局前置守卫放行了,你才能访问到对应的路由
consle.log(to)
注意fullPath和path的区别

/ 全局前置守卫: 所有的路由在被真正访问之前, 都会先经过全局前置守卫
// 只有全局前置守卫放行了, 才能真正的访问到你需要访问的路由
// to 到哪去
// from 从哪来
// next 是一个函数, 决定了是否放行, next()放行, next('/login')拦截到登录
// 将来的页面两种情况:
// 1. 需要授权才能访问  个人中心页, 我的收藏, 我的关注 ...
// 2. 不需要授权, 可以直接访问的  首页 登录页 注册页
// 这个数组中, 专门存放所有需要授权的路径
const AuthUrls = ['/profile']

router.beforeEach((to, from, next) => {
  // 需要授权的 和 不需要授权访问的处理是不一样的
  // 1. 如果要去的路径, 在授权数组中, 说明需要授权才能访问
  // console.log(to.path)  // /profile
  if (AuthUrls.includes(to.path)) {
    // 2. 需要授权访问的路径, 判断有没有token令牌
    //    有token放行, 没有token, 拦截到登录
    const token = localStorage.getItem('token')
    if (token) {
      next()
    } else {
      next('/login')
    }
  } else {
    // 不需要授权访问的路径, 放行
    next()
  }
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值