Vue路由守卫

一、全局路由守卫

(一)meta配置项

我们能够在路由组件中配置meta配置项,便于我们存储组件的相关信息(如:该组件展示时的标题名,访问该组件时是否需要权限校验)

meta : { a : xxx, b : xxx }

(二)全局前置路由守卫

该路由守卫会在应用初始化和切换页面时调用。

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

// 权限判断

next();

} )

我们能通过to和from参数拿到我们路径跳转的相关信息。

我们在下面的例子中在页面跳转的时候进行权限判断:

注意:使用前置路由和后置路由都要接收VueRouter实例对象然后暴露。

(三)全局后置路由守卫

后置路由守卫在初始化和页面跳转的时候调用。

router.afterEach( (to, from)=>{

// 页面跳转后的操作

})

比如我们可以用来修改路径跳转后的网页标题:

二、独享路由守卫

独享路由守卫就是给一个路由组件单独添加一个路由守卫,在路由组件中进行配置:

beforeEnter(to, from, next) {

// 权限判断

next();

}

其作用和全局前置路由守卫相同,全局前置路由守卫是给所有的组件路由添加路由守卫。

三、组件路由守卫

组件路由守卫就像组件的声明周期函数一样,在进入或离开该组件的时候被调用。

(一)进入路由守卫

进入该组件的时候就会调用进入路由守卫。

beforeRouteEnter (to, from, next) {

// 进去页面前操作

next();

}

(二)离开路由守卫

离开该组件的时候就会调用进入路由守卫。

beforeRouteLeave (to, from, next) {

// 离开页面前操作

next();

}

相关推荐
前端小菜鸟也有人起2 分钟前
浏览器不支持vue router
前端·javascript·vue.js
腥臭腐朽的日子熠熠生辉5 分钟前
nest js docker 化全流程
开发语言·javascript·docker
奔跑的web.5 分钟前
Vue 事件系统核心:createInvoker 函数深度解析
开发语言·前端·javascript·vue.js
再希10 分钟前
TypeScript初体验(四)在React中使用TS
javascript·react.js·typescript
携欢10 分钟前
[特殊字符] 一次经典Web漏洞复现:修改序列化对象直接提权为管理员(附完整步骤)
前端·安全·web安全
晨旭缘11 分钟前
前端视角 | 从零搭建并启动若依后端(环境配置)
前端
江公望16 分钟前
VUE3中,reactive()和ref()的区别10分钟讲清楚
前端·javascript·vue.js
攀登的牵牛花19 分钟前
前端向架构突围系列 - 框架设计(二):糟糕的代码有哪些特点?
前端·架构
EndingCoder29 分钟前
函数基础:参数和返回类型
linux·前端·ubuntu·typescript
码客前端35 分钟前
理解 Flex 布局中的 flex:1 与 min-width: 0 问题
前端·css·css3