Vue实现路由守卫的示例代码

 更新时间:2025年09月25日 08:30:55   作者:一只游鱼  
Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、概念

路由守卫(Navigation Guards)本质上就是 在路由跳转前后,拦截用户导航并做一些逻辑处理的钩子函数
常见用途有:

  • 鉴权控制:比如没有登录就不允许进入某些页面。
  • 数据预加载:在进入某个页面前,提前拉取数据。
  • 页面跳转控制:比如离开页面前弹出“是否保存更改”的提示。

简单理解:路由守卫就是 Vue Router 提供的一种“钩子函数”,用来控制页面导航的行为。

二、类型

Vue Router 提供了三类守卫:

(1)全局守卫

对所有路由跳转都生效。

// 全局前置守卫
router.beforeEach((to, from, next) => {
  const token = localStorage.getItem('token')
  if (to.meta.requiresAuth && !token) {
    // 需要登录,但没 token,跳转到登录
    next('/login')
  } else {
    next()
  }
})
// 全局后置守卫(一般用来修改标题等)
router.afterEach((to) => {
  document.title = to.meta.title || '默认标题'
})
export default router

(2)路由独享守卫

只针对某一个路由生效。

{
  path: '/profile',
  component: () => import('@/views/Profile.vue'),
  beforeEnter: (to, from, next) => {
    const token = localStorage.getItem('token')
    if (!token) {
      next('/login')
    } else {
      next()
    }
  }
}

(3)组件内守卫

直接写在组件里,对进入/离开当前组件生效。

export default {
  name: 'Profile',
  // 进入当前组件之前
  beforeRouteEnter(to, from, next) {
    console.log('即将进入 Profile 页面')
    next()
  },
  // 路由更新(比如 /profile/1 -> /profile/2)
  beforeRouteUpdate(to, from, next) {
    console.log('路由参数变化,更新页面数据')
    next()
  },
  // 离开当前组件时
  beforeRouteLeave(to, from, next) {
    const answer = window.confirm('确定要离开吗?未保存的数据会丢失')
    if (answer) {
      next()
    } else {
      next(false) // 阻止导航
    }
  }
}

三、实战

以下为作者的演示:

  1. 全局守卫
  2. 如果token过期或token错误会返回到登录页面

注意:以上效果需要配合JWT来实现,详情请看我的博客文章:

JWT令牌

在index.Js文件中写入全局守卫:

// 全局前置守卫
router.beforeEach((to, from, next) => {
  const token = localStorage.getItem('token') // 从本地取 token
  if (to.meta.requiresAuth && !token) {
    // 如果需要登录且没有 token,就跳到登录页
    next({ path: '/' })
  } else {
    next() // 其他情况放行
  }
})

在request.Js中添加拦截器:

// 响应拦截器:统一处理 401
request.interceptors.response.use(
  (response) => response,
  (error) => {
    if (error.response && error.response.status === 401) {
      localStorage.removeItem("token"); // 清除过期 token
      router.push("/"); // 跳转到登录页
    }
    return Promise.reject(error);
  }
);

可以试验一下,登录成功进入ai页面后:

打开F12,打开本地存储,将token删除,回到页面,并刷新。。

这时当前端发送的请求头不带token令牌时,后端会返回401,,axois拦截器会拦截到并且退回登录页面:

到此这篇关于Vue实现路由守卫的示例代码的文章就介绍到这了,更多相关Vue 路由守卫内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue通过axios调用json地址数据的方法

    Vue通过axios调用json地址数据的方法

    在现代Web开发中,前后端分离已成为标准做法,Vue.js作为前端框架中的佼佼者,提供了丰富的API来处理数据和服务端的交互,其中一个常用的库是axios,本文将详细介绍如何在Vue项目中使用axios来调用JSON数据,需要的朋友可以参考下
    2024-09-09
  • vue页面图片不显示问题解决方案

    vue页面图片不显示问题解决方案

    这篇文章主要介绍了vue页面图片不显示问题解决方案,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • Vue.set()实现数据动态响应的方法

    Vue.set()实现数据动态响应的方法

    这篇文章主要介绍了Vue.set()实现数据动态响应的相关知识,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-02-02
  • Vue实现带参数的自定义指令示例

    Vue实现带参数的自定义指令示例

    这篇文章主要为大家介绍了Vue实现带参数的自定义指令示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • vue.js利用Object.defineProperty实现双向绑定

    vue.js利用Object.defineProperty实现双向绑定

    这篇文章主要为大家详细介绍了vue.js利用Object.defineProperty实现双向绑定,帮大家解析神秘的Object.defineProperty方法
    2017-03-03
  • 使用 Vue 3 的 createApp方法初始化应用的基本步骤

    使用 Vue 3 的 createApp方法初始化应用的基本步骤

    createApp 是 Vue 3 引入的全局 API,用于创建一个应用实例,这篇文章主要介绍了如何使用 Vue 3 的 createApp方法初始化应用,通过 createApp 方法,我们从 Vue 3 的基本初始化开始,扩展到插件的应用、多个应用实例的创建等,需要的朋友可以参考下
    2024-05-05
  • 浅析vue数据绑定

    浅析vue数据绑定

    本文主要介绍了vue数据绑定的相关知识,具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Vue封装Swiper实现图片轮播效果

    Vue封装Swiper实现图片轮播效果

    图片轮播是前端中经常需要实现的一个功能。最近学习Vue.js,就针对Swiper进行封装,实现一个简单的图片轮播组件。感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-02-02
  • 基于vue3+antDesign2+echarts 实现雷达图效果

    基于vue3+antDesign2+echarts 实现雷达图效果

    这篇文章主要介绍了基于vue3+antDesign2+echarts 实现雷达图,本文通过实例代码图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • Vue父子组件元素获取方法互相调用示例详解

    Vue父子组件元素获取方法互相调用示例详解

    这篇文章主要为大家介绍了Vue父子组件元素获取方法互相调用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09

最新评论