导航 守卫
作用:对路由进行 权限控制 分类:全局守卫、独享守卫、组件内守卫
全局守卫
const router = new VueRouter({ routes: [ { path: '/home', component : Home, meta: { isAuth: false }, // 不需要进行权限控制 }, { path: '/user', component: User, meta: { isAuth: true }, // 需要进行权限控制 }, ] }) // 全局前置守卫:初始化时执行/每次路由切换前执行 router.before each ((to, From ,next) => { if(to.meta.isAuth) { // 判断当前路由 是否 需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性) if(localStorage.get IT em('xxx') === 'xxx') { // 权限控制的具体规则 next(); // 放行 }else { .. . } } else { // 当前路由不需要进行权限控制 next(); // 直接放行 } }) // 全局后置守卫:初始化时执行,每次路由切换后执行 router.afterEach((to,f rom ) => { if(to.meta.title) { document.title = to.meta.title; // 修改网页的title }else { document.title = 'xxx'; } })
独享守卫
加在某个路由的配置中
beforeEnter((to,from,next) => { if(to.meta.isAuth) { // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性) if(localStorage.getItem('xxx') == = 'xxx') { // 权限控制的具体规则 next(); // 放行 }else { ... } } else { // 当前路由不需要进行权限控制 next(); // 直接放行 } })
组件内守卫
// 进入守卫,通过路由规则,进入该组件时被调用 beforeRouteEnter(to,from,next){ ... } // 当前路由 改变 ,但是该组件被复用 时调 用 // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候, // 由于会渲染同样的 Foo 组件,组件实例会被复用。而这个钩子就会被调用 beforeRouteUpdate(to,from,next{ ... } // 离开守卫,通过路由规则,离开该组件时被调用 beforeRouteLeave(to,from,next){ ... }
vue导航守卫有 哪些
路由的钩子函数有六个
全局的路由钩子函数:beforeEach、afterEach 单个路由的钩子函数:beforeEnter 组件内路由钩子函数:beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave
全局路由钩子函数
1、全局前置守卫: beforeEach(to, from, next)
router.beforeEach : 在每次每一个路由改变的时候都会执行一遍
to :将要进入的路由对象 from : 当前正要离开的路由对象 nextnext() ,进入下一个路由,必须调用,不然不会跳转
next(false) : 中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动 或者 浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。
next(’/’) 或者 next({ paht:’/’}) :跳转到一个不同的地址。当前的导航会被中断,然后进行一个新的导航。可传递的参数可以是 router-link 标签中的 to 属性参数或 router.push 中的选项
应用场景:可进行一些页面跳转前处理,例如判断需要登录的页面进行拦截,做登录跳转, 还有管理员权限判断。
2、全局后置守卫:afterEach(to, from)
router.afterEach: 和 beforeEach 相反,它是在路由跳转完成后触发,它发生在 beforeEach 之后 beforeRouteEnter(组件内守卫) 之前, 因为是跳转完成后触发,所以没有 next 参数。
路由内的钩子函数
路由独享守卫:beforeEnter(to, from, next)
和 beforeEach 完全相同,如果两个都设置了,beforeEnter 则在 beforeEach 之后紧随执行。在路由配置上直接定义 beforeEnter 守卫
组件内的钩子函数
是指在组件内执行的钩子函数,类似于组件内的生命周期
组件前置守卫 beforeRouteEnter: 该钩子在全局守卫 beforeEach 和独享守卫 beforeEnter 之后。 组件更新守卫 beforeRouteUpdate:在当前路由改变时,并且该组件被复用时调用。 组件离开守卫 beforeRouteLeave:导航离开该组件的对应路由时调用const Foo = { template: `...`, beforeRouteEnter (to, from, next) { // 在渲染该组件的对应路由被 confirm 前调用 // 不!能!获取组件实例 `this` // 因为当钩子执行前,组件实例还没被创建 }, beforeRouteUpdate (to, from, next) { // 在当前路由改变,但是该组件被复用时调用 // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候, // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。 // 可以访问组件实例 `this` }, beforeRouteLeave (to, from, next) { // 导航离开该组件的对应路由时调用 // 可以访问组件实例 `this` }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的 文章 : Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解 vue-router的导航守卫使用最新讲解 Vue Router4路由导航守卫实例全面解析 关于Vue中的全局导航守卫(beforeEach、afterEach) 快速理解Vue路由导航守卫
总结
以上是 为你收集整理的 vue中的导航守卫使用及说明 全部内容,希望文章能够帮你解决 vue中的导航守卫使用及说明 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。