【Vue3从零开始-实战】S6:路由守卫实现登录校验功能

简介: 【Vue3从零开始-实战】S6:路由守卫实现登录校验功能

@@DVBVTGC2D7ROIYF4YK_@O.png


前言


实战已经开始了!在前面几篇文章中,我们将首页的各个组件完成了,还将登录页的布局实现了。并且把路由配置完成了。在本篇文章中会使用路由守卫实现基础登录校验功能,为了循序渐进,复杂的方式会在后面的文章中完善。


全局路由守卫beforeEach


beforeEach:表示路由跳转时执行的函数。 🌀 比如我们的项目需要先登录,然后才能看到首页。但是现在我们打开根路由的时候,可以直接看到首页,并不需要登录。那么我们就可以在beforeEach函数中去判断一下。


👉 打开router目录下的index.js文件


()~C8ZV}7FX~9Y9M8_@G(YE.png


👆 在创建路由之后使用beforeEach函数


router.beforeEach((to, from, next) => {
  console.log(to, from)
  next()
})
复制代码


🔆 beforeEach函数中有一个回调函数,回调函数中接收三个参数:to、from、next


  • to:即将要进入的目标路由。


  • from:当前导航正在离开的路由。


  • next:可以理解为一个中间件,表示继续执行的方法。


next是一个函数,也是beforeEach中必须要调用的钩子函数。


85RROA8DH5MJ4@~VHSJN@}7.png


⭕️ 在浏览器控制台中可以看到打印出来的内容里面都是路由配置中写到的:name、path等信息。


校验登录


既然beforeEach函数中可以在路由跳转之前执行,那么我们就可以在函数中判断一下是否有登录,如果有就继续执行跳转,否则就跳转到登录页。


router.beforeEach((to, from, next) => {
  if (isLogin) {
    next()
  } else {
    next({ name: 'Home' })
  }
})
复制代码


  • next函数中接收一个对象,对象里面的name就是路由配置中的name,也是跳转路由的名称。


9X0G{0P@CFMFF62FLG63~{6.png


🚫 当我们访问根路由的时候,好像并没有校验登录,而是在控制台报错了。


⭕️ 这是因为路由守卫在执行过程中发现如果我们直接访问登录页的时候,也会校验isLogin,当它为false的时候,也会去访问登录页,这样就是一个死循环了。一直校验就会一直跳转登录页。


🔥 所以我们在判断是否登录的时候,还要顺便判断一下目标路由是否为登录页。


router.beforeEach((to, from, next) => {
  const isLogin = false
  if (isLogin || to.name === 'Login') {
    next()
  } else {
    next({ name: 'Login' })
  }
})
复制代码


  • 在上面打印 to 的值时,里面也是有一个name,表示路由配置里面的名称。


$SM8`R5T9V2J)Z4`H8F0_$L.png


🔆 现在我们不管怎么操作路由,都会跳转到登录页了。


登录跳转


🌀 进入登录页已经校验成功了,下面就该点击登录跳转到首页去了。


👉 打开Login.vue文件。


1%Y8~ZM4)5XTJW(CT0D%JG6.png


☝️ 在Login.vue中给登录按钮一个点击事件


<div class="wrapper__login-button" @click="handleLogin">登陆</div>
复制代码


✌️ 在js中引入useRouter用于路由跳转


import { useRouter } from 'vue-router'
复制代码


👌 在setup中使用useRouter函数跳转到首页


setup () {
    const router = useRouter()
    const handleLogin = () => {
      router.push({ name: 'Home' })
    }
    return { handleLogin }
}
复制代码


❗️最关键的一步就是要把beforeEach中的登录校验改为true,否则校验不成功就不会跳转的。


router.beforeEach((to, from, next) => {
  const isLogin = true
  if (isLogin || to.name === 'Login') {
    next()
  } else {
    next({ name: 'Login' })
  }
})
复制代码

网络异常,图片无法展示
|

局部路由守卫beforeEnter


beforeEnter:表示加载到当前路由之前需要执行的钩子函数


😲 虽然我们在beforeEach函数中定义了isLogin = true,但是当我们在浏览器地址栏后面加上login路由时,还是会跳转到登录页。


XZJPP~}QS9(TA8O9QD}UCSJ.png


😫 这样登录就没有意义了,所以我们需要将isLogin的值存起来,方便我们后面判断。

  1. 在登录按钮点击事件中,将isLogin存储到localStorage


const handleLogin = () => {
  localStorage.isLogin = true
  router.push({ name: 'Home' })
}
复制代码


  1. 在beforeEach 中通过获取localStorage中的isLogin来校验


router.beforeEach((to, from, next) => {
  const { isLogin } = localStorage
  if (isLogin || to.name === 'Login') {
    next()
  } else {
    next({ name: 'Login' })
  }
})
复制代码


  1. 在路由配置中,login配置下面使用beforeEnter函数通过判断isLogin来校验是否需要进入登录页


const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  }, {
    path: '/login',
    name: 'Login',
    component: Login,
    beforeEnter (to, from, next) {
      const { isLogin } = localStorage
      isLogin ? next({ name: 'Home' }) : next()
    }
  }
]
复制代码


XZJPP~}QS9(TA8O9QD}UCSJ.png

总结


本章节主要是将登录页和首页进行关联,并把路由中的钩子函数讲解了一点。

在登录的时候,我们并没有校验用户名和密码,因为重点不在这里,所以有兴趣的同学可以自己实现一下看看哦~

相关文章
|
9月前
|
人工智能 自然语言处理 JavaScript
通义灵码2.5实战评测:Vue.js贪吃蛇游戏一键生成
通义灵码基于自然语言需求,快速生成完整Vue组件。例如,用Vue 2和JavaScript实现贪吃蛇游戏:包含键盘控制、得分系统、游戏结束判定与Canvas动态渲染。AI生成的代码符合规范,支持响应式数据与事件监听,还能进阶优化(如增加启停按钮、速度随分数提升)。传统需1小时的工作量,使用通义灵码仅10分钟完成,大幅提升开发效率。操作简单:安装插件、输入需求、运行项目即可实现功能。
464 4
 通义灵码2.5实战评测:Vue.js贪吃蛇游戏一键生成
|
11月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
598 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
9月前
|
JavaScript API 容器
Vue 3 中的 nextTick 使用详解与实战案例
Vue 3 中的 nextTick 使用详解与实战案例 在 Vue 3 的日常开发中,我们经常需要在数据变化后等待 DOM 更新完成再执行某些操作。此时,nextTick 就成了一个不可或缺的工具。本文将介绍 nextTick 的基本用法,并通过三个实战案例,展示它在表单验证、弹窗动画、自动聚焦等场景中的实际应用。
864 17
|
10月前
|
存储 JavaScript 前端开发
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
871 6
|
JavaScript 前端开发
【Vue.js】监听器功能(EventListener)的实际应用【合集】
而此次问题的核心就在于,Vue实例化的时机过早,在其所依赖的DOM结构尚未完整构建完成时就已启动挂载流程,从而导致无法找到对应的DOM元素,最终致使计算器功能出现异常,输出框错误地显示“{{current}}”,并且按钮的交互功能也完全丧失响应。为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把HTML文件中标签内的JavaScript代码迁移到外部的JS文件里,随后在HTML文件中对其进行引用。
210 8
|
5月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
506 2
|
4月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
427 137
|
8月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
976 0
|
8月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
9月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1242 78