首页前端开发VUEvue中的导航守卫使用及说明

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

时间2024-02-11 05:24:03发布访客分类VUE浏览702
导读:收集整理的这篇文章主要介绍了vue中的导航守卫使用及说明,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录导航守卫全局守卫独享守卫组件内守卫vue导航守卫有哪些路由的钩子函数有六个...
收集整理的这篇文章主要介绍了vue中的导航守卫使用及说明,觉得挺不错的,现在分享给大家,也给大家做个参考。
目录
  • 导航守卫
    • 全局守卫
    • 独享守卫
    • 组件内守卫
  • vue导航守卫有哪些
    • 路由的钩子函数有六个
    • 全局路由钩子函数
    • 路由内的钩子函数
    • 组件内的钩子函数
  • 总结

    导航守卫

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

    全局守卫

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

    总结

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

    您可能感兴趣的文章:
    • Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解
    • vue-router的导航守卫使用最新讲解
    • Vue Router4路由导航守卫实例全面解析
    • 关于Vue中的全局导航守卫(beforeEach、afterEach)
    • 快速理解Vue路由导航守卫

    声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


    若转载请注明出处: vue中的导航守卫使用及说明
    本文地址: https://pptw.com/jishu/609375.html
    Vue项目如何获取本地文件夹绝对路径 vue table表格中如何控制下拉框的显示隐藏

    游客 回复需填写必要信息