vue中路由守卫钩子函数的使用

Vue 中的路由守卫是用于管理路由变化时的钩子函数,常用于权限控制。beforeEach 钩子提供 to、from 和 next 三个参数,分别代表目标路由、来源路由和继续执行导航的方法。通过这些参数,可以判断用户登录状态、角色权限,并据此决定是否允许访问特定页面。例如,当用户未登录且试图访问非登录页时,可以重定向至登录页。通过路由守卫,可以优雅地解决项目中的权限问题,确保页面跳转的合理性。
摘要由CSDN通过智能技术生成

vue中路由守卫钩子函数的使用

什么是路由守卫钩子函数?

在日常的vue项目开发过程中,大多的项目会涉及到权限问题:

登陆与未登录状态的管理

登陆后不同角色所看到的内容的区别
顾名思义,守卫就是时时刻刻的守护着你,路由守卫就是用于实时监听路由的变化,根据变化做出各种处理方式;vue-router里提供了一个beforeEach的方法,它就是我们常用到的路由钩子函数(还有个afterEach钩子函数,不常用)

如何进行路由守卫与检测?

其中这个方法提供了三个参数beforeEach(to, from, next),关于这三个参数的使用:

to:是个对象,你将要跳转的目标路由;这一步你就可以通过你当前的状态(是否登陆或角色的权限)来决定你是否跳转到当前页面。
from: 是个对象, 你从哪里跳转过来;这一步你可以通过从不同渠道到当前页面来进行相应的处理。
next: 是个方法,如果你使用了路由守卫,那你要想进行路由跳转时就必选使用next(),路由才会进行相应的跳转;next()函数也可以传入一个参数,例如:next({ path: '/index' }),它的含义是路由跳转的目标将是index页面;还可以通过传入false来中断此次路由的跳转。

以上就是路由守卫的主要使用方法,下面举个vue-router路由守卫的实例:

import Router from 'vue-router' //首先需要导入包

// 接下来就可以在下面函数内部进行路由的各种管理控制
Router.beforeEach((to, from, next) => { 
  	if (!localStorage.getItem('token')) { // 例如你把token存入本地,你就可以通过它来判断是否需要跳转到登录页
  		if (to.path === '/login' || to.path === '/register') {// 对于登陆注册页完全开发
  			next()
  		} else {
  			next({ path: '/login' })
  		}
  	} else {
  		const level = user.xxx // 我们假设level是用户登陆后获取的身份等级,level = 1是普通用户,level = 2是vip用户
  		if (level === 1) {
  			if (to.path !== '/index') { 例如:我们只让普通会员只能看index页面
  				next({ path: '/index' })
  			}
  		} else if (level === 2) {// 对于vip用户,可以看到所有的页面
  			next()
  		}
	}
})
export default Router // 最后把我们封装好的路由守卫暴露出去,在main.js中引入即可

在实际项目开发中,对于涉及到权限问题的,选择路由守卫钩子函数能够更好的解决页面跳转问题;以上就是我对vue中路由守卫钩子函数的理解,希望能够对你有所帮助!

原文链接:https://blog.csdn.net/Mrcaolei/article/details/108401174

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值