锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. 前端
  4. vue路由的钩子函数

vue路由的钩子函数

0
  • 前端
  • 发布于 2024-09-26
  • 0 次阅读
黄健
黄健

在Vue.js中,当使用Vue Router进行页面路由管理时,你可以利用路由守卫(Route Guards)来实现路由的钩子函数。这些钩子函数允许你在路由发生变化时执行一些代码,比如权限验证、页面加载前的数据预获取等。Vue Router 提供了全局守卫、路由独享的守卫以及组件内的守卫。

1. 全局守卫

  • beforeEach:全局前置守卫,在路由跳转前触发,每个路由跳转都会经过这个守卫。
  • beforeResolve:在解析守卫之后调用,即在所有嵌套路径的组件内守卫和异步组件被解析之后调用。
  • afterEach:全局后置钩子,路由跳转后触发,不接受 next 函数,也不会改变导航本身。

2. 路由独享的守卫

  • beforeEnter:在路由配置中直接定义,进入路由前调用,参数为 to, from, next。

3. 组件内的守卫

  • beforeRouteEnter :在渲染该组件的对应路由被 confirm 前调用,此时组件实例还没被创建,不能获取组件实例 this。可以通过传一个回调给 next 来访问组件实例。
  • beforeRouteUpdate (2.2+):在当前路由改变,但是该组件被复用时调用,例如,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,由于会渲染同样的 Foo 组件,因此这个守卫就被调用,而不是销毁后重新创建。
  • beforeRouteLeave :导航离开该组件的对应路由时调用,可以访问组件实例 this。

示例

全局前置守卫 beforeEach

|—|————————————————————————-|
| | router.beforeEach((to, from, next) => { |
| | // 权限验证等逻辑 |
| | if (to.name !== 'Login' && !isAuthenticated) next({ name: 'Login' }) |
| | else next() |
| | }) |

组件内的守卫 beforeRouteEnter

|—|—————————————-|
| | export default { |
| | beforeRouteEnter (to, from, next) { |
| | // 在渲染该组件的对应路由被 confirm 前调用 |
| | // 不!能!获取组件实例 `this` |
| | // 因为当守卫执行前,组件实例还没被创建 |
| | next(vm => { |
| | // 通过 `vm` 访问组件实例 |
| | }) |
| | } |
| | } |

组件内的守卫 beforeRouteLeave

|—|——————————————————————————————–|
| | export default { |
| | beforeRouteLeave (to, from, next) { |
| | // 导航离开该组件的对应路由时调用 |
| | // 可以访问组件实例 `this` |
| | const answer = window.confirm('Do you really want to leave? you have unsaved changes!') |
| | if (answer) { |
| | next() |
| | } else { |
| | next(false) |
| | } |
| | } |
| | } |

路由守卫是Vue Router中非常强大的功能,能够让你对路由的导航过程进行精细的控制。

原文链接: https://blog.csdn.net/hexadecimal_001/article/details/140506468

标签: #VUE 61 #前端 145
相关文章

vue2路由和vue3路由区别及原理 2024-10-08 11:24

一、Vue2 与 Vue3 路由的区别 1. 创建路由实例方式的不同 Vue 2 中,通过 Vue.use() 注册路由插件,并通过 new VueRouter() 来创建路由实例。 import Vue from 'vue';import VueRouter from 'vue-router';i

vue项目 部署到nginx 上刷新页面显示404 2024-09-30 17:34

在Vue项目部署到Nginx服务器上时,遇到刷新页面显示404的问题,通常是因为Nginx无法正确地处理Vue路由(尤其是单页面应用(SPA)中的前端路由)。Vue应用的路由是前端路由,依赖于JavaScript来动态解析URL,当直接访问除根路径外的URL时,Nginx默认会尝试在服务器上找到对应

三小时快速上手TypeScript,TS速通教程(上篇、中篇、下篇、附加篇) 2024-09-29 11:21

TypeScript速通 Typescript简介 为什么需要TypeScript * JavaScript今非昔比 JavaScript中的困扰 1. 不清不楚的数据类型 2. 有漏洞的逻辑 3. 访问不存在的属性 4. 低级的拼写错误 TypeScrip

js中的事件冒泡是什么? 2024-09-29 11:21

事件冒泡(Event Bubbling)是JavaScript中一种事件传播机制。当一个事件(如点击、键盘输入等)发生在某个元素上时,浏览器会首先触发该元素上的特定事件处理函数(如果存在的话)。然后,该事件会从当前元素向其父元素逐级传播,直到达到元素或整个文档树。这种从触发元素开始,逐级向上传播的事

Vue.js 的 Mixins 2024-09-26 17:57

Vue.js 的 Mixins 是一种非常强大且灵活的功能,它允许你封装可复用的 Vue 组件选项。Mixins 实际上是一种分发 Vue 组件可复用功能的非常灵活的方式。一个 mixin 对象可以包含任意组件选项。当组件使用 mixin 时,所有 mixin 选项将被"混入"该组件本身的选项。 M

前端框架对比和选择 2024-09-26 17:57

在前端开发的广阔领域中,框架的选择对于项目的成功至关重要。不同的框架各具特色,适用于不同的开发需求和项目规模。本文将对当前最流行的三大前端框架——React、Vue和Angular进行详细对比,并探讨如何根据项目需求选择合适的框架。 一、React 1. 简介 React是由Facebook开发和维

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.