vue3 导航守卫

简介: Vue3中的导航守卫与Vue2中的类似,用于在路由跳转过程中进行控制和处理。Vue3提供了三种导航守卫:全局前置守卫、路由独享守卫和组件内守卫。

Vue3中的导航守卫与Vue2中的类似,用于在路由跳转过程中进行控制和处理。Vue3提供了三种导航守卫:全局前置守卫、路由独享守卫和组件内守卫。


全局前置守卫


全局前置守卫是在路由跳转前进行拦截的守卫,可以用来进行用户身份验证、处理路由参数等操作。在Vue3中,可以通过router.beforeEach方法来定义全局前置守卫:

const router = createRouter({
  history: createWebHistory(),
  routes: [...]
})
router.beforeEach((to, from, next) => {
  // to: 即将跳转的路由对象
  // from: 当前导航正要离开的路由
  // next: 用来确认跳转的函数
  // 用户身份验证
  if (to.meta.requireAuth) {
    const token = localStorage.getItem('token')
    if (token) {
      next()
    } else {
      next('/login')
    }
  } else {
    next()
  }
})

路由独享守卫


路由独享守卫是在单个路由配置中进行拦截的守卫,可以用来进行特定路由的身份验证、处理路由参数等操作。在Vue3中,可以通过beforeEnter配置项来定义路由独享守卫:

const router = createRouter({
  history: createWebHistory(),
  routes: [
    {
      path: '/account',
      component: Account,
      beforeEnter: (to, from, next) => {
        // 路由独享守卫
        const token = localStorage.getItem('token')
        if (token) {
          next()
        } else {
          next('/login')
        }
      }
    }
  ]
})

组件内守卫


组件内守卫是在单个Vue组件中进行拦截的守卫,可以用来进行特定组件的身份验证、处理组件参数等操作。在Vue3中,可以通过beforeRouteEnter、beforeRouteUpdate和beforeRouteLeave三种方法来定义组件内守卫:

const Account = {
  template: `
    <div>
      <h1>My Account</h1>
      <p>{{username}}</p>
    </div>
  `,
  beforeRouteEnter(to, from, next) {
    // 组件内守卫 - beforeRouteEnter
    const token = localStorage.getItem('token')
    if (token) {
      next(vm => {
        // 在路由导航确认前执行,可以访问组件实例
        vm.username = localStorage.getItem('username')
      })
    } else {
      next('/login')
    }
  },
  beforeRouteUpdate(to, from, next) {
    // 组件内守卫 - beforeRouteUpdate
    const token = localStorage.getItem('token')
    if (token) {
      this.username = localStorage.getItem('username')
      next()
    } else {
      next('/login')
    }
  },
  beforeRouteLeave(to, from, next) {
    // 组件内守卫 - beforeRouteLeave
    const answer = confirm('Are you sure you want to leave?')
    if (answer) {
      next()
    } else {
      next(false)
    }
  },
  data() {
    return {
      username: ''
    }
  }
}


相关文章
|
2天前
|
JavaScript 前端开发 CDN
vue3速览
vue3速览
11 0
|
2天前
|
设计模式 JavaScript 前端开发
Vue3报错Property “xxx“ was accessed during render but is not defined on instance
Vue3报错Property “xxx“ was accessed during render but is not defined on instance
|
2天前
|
缓存 JavaScript 前端开发
Vue3 官方文档速通(中)
Vue3 官方文档速通(中)
9 0
|
2天前
|
缓存 JavaScript 前端开发
Vue3 官方文档速通(上)
Vue3 官方文档速通(上)
9 0
|
2天前
Vue3+Vite+Pinia+Naive后台管理系统搭建之五:Pinia 状态管理
Vue3+Vite+Pinia+Naive后台管理系统搭建之五:Pinia 状态管理
7 1
|
3天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
3天前
|
JavaScript 数据库
ant design vue日期组件怎么清空 取消默认当天日期
ant design vue日期组件怎么清空 取消默认当天日期
|
3天前
|
JavaScript C++
vue高亮显示组件--转载
vue高亮显示组件--转载
8 0
|
2天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
8 1
|
2天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
10 0