路由守卫是什么?
路由守卫又称导航守卫,指的是路由在跳转前、中、后过程中的一些钩子函数,这些函数可以让你操作一些其他的事,常作用于某些后台管理系统在设置权限的时候,在实现路由跳转前校验是否有权限,有权限就可以通过,反之就会被执行其他操作,如返回登录页。
路由守卫的分类
一、全局守卫
- 全局前置守卫beforeEach
在路由跳转前触发,这个钩子作用主要是用于登录验证,判断用户是否满足登录要求,满足就跳转到其他页面,不满足就强制跳转到登录页。
router.beforeEach((to, from, next) => {
})
- 全局解析守卫beforeResolve
在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。
router.beforeResolve((to, from, next) => {
})
- 全局后置守卫afterEach(参数中没有next)
router.afterEach((to, from) => {
})
二、组件内的守卫
- beforeRouteEnter
不能访问 this,因为守卫在路由确认前被调用,组件还没有被创建
beforeRouteEnter (to, fromnext) {}
- beforeRouteUpdate
在当前路由改变,但是该组件复用时调用,举例来说,对于一个带有动态数的路径 /foo/:id,在 /foo/1和 /foo/2 之间跳转的时候,由于会渲染同样的 Foo 组件因此组件实例会被复用。而这个就会在这个情况下被调用。
beforeRouteUpdate (to, from,next) {
// 可以访问组件实例 `this`
}
- beforeRouteLeave
这个离开守卫通常用来禁止用户在还未保存信息前突然离开。该导航可以通过 next(false) 来取消。
beforeRouteLeave (to, from,next) {
// 导航离开该组件的对应路由时用
// 可以访问组件实例 `this`
}
三、路由独享的守卫
- beforeEnter
用法与全局守卫一致。只是,将其写进其中一个路由对象中,只在这个路由下起作用。
const router = new VueRouter({
routes: [
{
path: '/foo',
component: Foo,
beforeEnter: (to, from, next) => {
// ...
// 只在foo路由下起作用
}
}
]
})
路由守卫的参数
1、to
- 即将要跳转的路由
- 相当于$router
2、from
- 当前离开的路由
3、next()
以下是next()的常见的用法:
(1)next(),表示可以放行,跳转到需要跳转的路由
(2)next('路径'),表示强制跳转到某个路由。例如:next('/login')表示强制跳转到登录页
(3)next(false),中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。