vue学习-15vue全局路由守卫

在vue.js中,提供三种全局守卫,英文称作(Global Navigation Guards),这些守卫允许你在路由发生变化的时候执行的一些操作,例如身份验证,日志纪录或者路由跳转控制,全局路由守卫包含以下三种:

全局前置守卫 (beforeEach):这个守卫在每次路由切换前触发,允许你在导航到新路由之前进行一些检查或操作。常用于身份验证。

js 复制代码
router.beforeEach((to, from, next) => {
  // 在路由切换前执行的代码
  // 可以进行身份验证检查等
  next(); // 继续路由导航
});

全局解析守卫 (beforeResolve):这个守卫在导航被确认之前触发,它比beforeEach更早执行,但在路由组件渲染之前。它通常用于在路由渲染之前进行一些全局级别的处理。

js 复制代码
router.beforeResolve((to, from, next) => {
  // 在导航被确认前执行的代码
  next(); // 继续路由导航
});

全局后置守卫 (afterEach):这个守卫在每次路由切换后触发,通常用于记录路由导航信息或执行一些后续操作。

js 复制代码
router.afterEach((to, from) => {
  // 在路由切换后执行的代码
});

这些全局路由守卫可以通过Vue Router来设置,以便在整个应用程序范围内管理路由的行为。它们提供了强大的灵活性,可用于执行各种任务以满足应用程序的需求。

例如:

在全局前置守卫(beforeEach)完成一个示例:

js 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)

const router = new VueRouter({
  routes: [
    // 路由配置
  ]
})

router.beforeEach((to, from, next) => {
  // 在路由切换前执行的代码
  // 例如,检查用户是否登录,进行身份验证
  if (to.meta.requiresAuth && !userIsLoggedIn) {
    // 如果需要身份验证且用户未登录,可以重定向到登录页
    next('/login')
  } else {
    // 如果条件满足,继续路由导航
    next()
  }
})

export default router

全局解析守卫 (beforeResolve) 示例:

js 复制代码
router.beforeResolve((to, from, next) => {
  // 在导航被确认前执行的代码
  // 例如,在路由渲染前进行一些全局级别的操作
  someGlobalFunction()
  next()
})

全局后置守卫 (afterEach) 示例:

js 复制代码
router.afterEach((to, from) => {
  // 在路由切换后执行的代码
  // 例如,记录路由导航信息
  console.log(`Navigated from ${from.path} to ${to.path}`)
})

在使用vue全局路由守卫的时候需要注意的一些事项:

  1. 全局前置守卫在每次路由切换前都会执行,而全局后置钩子只有在路由切换完成后才会执行。
  2. 全局前置守卫中,next()函数必须调用,否则导航将无法继续。
  3. 如果在全局前置守卫中调用了next()函数,则不会执行全局后置钩子。
  4. 如果在全局前置守卫中没有调用next()函数,那么导航将会被中断,并抛出一个错误。
相关推荐
Moment几秒前
富文本编辑器技术选型,到底是 Prosemirror 还是 Tiptap 好 ❓❓❓
前端·javascript·面试
xkxnq5 分钟前
第二阶段:Vue 组件化开发(第 18天)
前端·javascript·vue.js
晓得迷路了6 分钟前
栗子前端技术周刊第 112 期 - Rspack 1.7、2025 JS 新星榜单、HTML 状态调查...
前端·javascript·html
怕浪猫9 分钟前
React从入门到出门 第五章 React Router 配置与原理初探
前端·javascript·react.js
jinmo_C++9 分钟前
从零开始学前端 · HTML 基础篇(一):认识 HTML 与页面结构
前端·html·状态模式
鹏多多16 分钟前
前端2025年终总结:借着AI做大做强再创辉煌
前端·javascript
我的xiaodoujiao16 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 39--生成 Allure测试报告
python·学习·测试工具·pytest
QiZhang | UESTC17 分钟前
学习日记day53
学习
qq_5710993518 分钟前
学习周报三十
学习
WebGISer_白茶乌龙桃21 分钟前
Cesium实现“悬浮岛”式,三维立体的行政区划
javascript·vue.js·3d·web3·html5·webgl