当前位置: 代码网 > it编程>前端脚本>Vue.js > vue中的导航守卫使用及说明

vue中的导航守卫使用及说明

2024年05月19日 Vue.js 我要评论
导航守卫作用:对路由进行权限控制分类:全局守卫、独享守卫、组件内守卫全局守卫const router = new vuerouter({ routes: [ { path: '/ho

导航守卫

  • 作用:对路由进行权限控制
  • 分类:全局守卫、独享守卫、组件内守卫

全局守卫

const router = new vuerouter({
  routes: [
    {
      path: '/home',
      component: home,
      meta: { isauth: false },	// 不需要进行权限控制
    },
     {
      path: '/user',
      component: user,
      meta: { isauth: true },	// 需要进行权限控制
    },
  ]
})
// 全局前置守卫:初始化时执行/每次路由切换前执行
router.beforeeach((to,from,next) => {
  if(to.meta.isauth) {  // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isauth属性)
    if(localstorage.getitem('xxx') === 'xxx') { // 权限控制的具体规则
      next();   // 放行
    }else {
      ...
    }
  } else {  // 当前路由不需要进行权限控制
    next(); // 直接放行
  }
})
// 全局后置守卫:初始化时执行,每次路由切换后执行
router.aftereach((to,from) => {
  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: 当前正要离开的路由对象
  • next

next(),进入下一个路由,必须调用,不然不会跳转

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`
  }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com