Vue Router v3 深入指南:配置、概念、代码演示及应用场景

Vue Router v3 深入指南:配置、概念、代码演示及应用场景

Vue Router 是 Vue.js 官方的路由管理器,它与 Vue.js 核心深度集成,使得构建单页面应用(SPA)变得简单。本文将详细介绍 Vue Router v3 的配置项、路由信息对象(Route Information Object, RIO)、代码演示及其在不同场景下的应用。

1. 路由实例配置项

在 Vue Router v3 中,路由实例配置项是设置路由行为的关键参数。以下是一些常用的配置项:

  • mode:定义路由模式,可以是 historyhashabstracthistory 模式使用 HTML5 History API,而 hash 模式使用 URL 的 hash 来模拟一个完整的 URL。
  • base:设置应用的基路径,默认为 /
  • routes:定义路由规则的数组,每个规则包括 pathcomponentname 等属性。
  • linkActiveClasslinkExactActiveClass:定义激活链接的类名。
  • scrollBehavior:定义路由切换时的滚动行为。
  • parseQuerystringifyQuery:定义解析和字符串化查询参数的函数。

代码演示

import { createRouter, createWebHistory } from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';const routes = [{ path: '/', component: Home },{ path: '/about', component: About }
];const router = createRouter({history: createWebHistory(),routes,scrollBehavior(to, from, savedPosition) {return { x: 0, y: 0 };}
});export default router;

2. 路由信息对象

路由信息对象(RIO)是 Vue Router 中用于存储当前路由状态的数据结构。它包含以下属性:

  • path:当前路由的路径。
  • params:包含动态路由参数的对象。
  • query:URL 查询参数的对象。
  • hash:当前路由的 hash 值。
  • fullPath:包含查询参数和 hash 的完整路径。
  • matched:包含当前路由的所有嵌套路径片段的路由记录数组。
  • name:当前路由的名称。

代码演示

在组件中访问路由信息对象:

export default {mounted() {console.log(this.$route.path); // 输出当前路径console.log(this.$route.query); // 输出查询参数}
};

3. 其他常用关键词和概念

  • router-view:用于渲染匹配的组件。
  • router-link:用于创建导航链接。
  • VueRouter:Vue Router 的实例,用于配置和管理路由。
  • dynamic route matching:动态路由匹配,使用参数来匹配路径。
  • route parameters:路由参数,动态路由中的参数。
  • query parameters:查询参数,URL 中的查询字符串参数。
  • navigation guards:导航守卫,用于在路由切换时执行自定义逻辑。

代码演示

全局前置守卫示例:

router.beforeEach((to, from, next) => {console.log('Global beforeEach guard');next();
});

4. 应用场景

Vue Router v3 适用于多种场景:

  • 单页应用(SPA):构建不重新加载页面的前端应用。
  • 模块化开发:通过模块化路由配置,组织大型应用。
  • 权限控制:使用路由守卫实现页面访问控制。
  • 代码分割:与 Vue 的异步组件和 Webpack 的代码分割功能结合,实现按需加载。

结论

Vue Router v3 提供了强大的路由管理功能,使得开发者能够构建灵活、高效的单页应用。通过理解路由实例配置项和路由信息对象,以及掌握相关的概念和代码实现,开发者可以更好地利用 Vue Router v3 来满足各种开发需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/54697.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

探索未来科技的无限可能:IT领域的深度剖析与前瞻

探索未来科技的无限可能:IT领域的深度剖析与前瞻 在这个日新月异的时代,信息技术(IT)如同一股不可阻挡的洪流,深刻地改变着我们的生活方式、工作模式乃至整个社会的运行逻辑。今天,让我们一同潜入IT的浩瀚…

关系型数据库 - MySQL II

基本概念 SQL 指令 SQL 指令是用于访问和处理数据库的标准的计算机语言。对于 MySQL 等常用数据库都可以通过使用 SQL 访问和处理数据系统中的数据。 注意事项 SQL 对大小写不敏感。标识符应避免与关键字重名!可用反引号()为标识符包裹。…

使用python写按键程序

主要用到的python库是PyAutoGUI,输入一下命令安装即可。 pip install pyautoguiPyAutoGUI官网:https://pyautogui.readthedocs.io/en/latest/ 下面做一些功能介绍,介绍部分的内容均来自官网。 部分函数简介 注意:下面函数大部…

Java之String 类的学习

目录 1. String类的重要性 2. 常用方法 2.1 字符串常用3种构造 2.2 String对象的4种比较 1. 比较是否引用同一个对象 2. boolean equals(Object anObject) 方法:按照字典序比较 3. int compareTo(String s) 方法: 按照字典序进行比较 4. int compar…

Java语言程序设计基础篇_编程练习题***18.33 (游戏:骑士旅途的动画)

目录 ***18.33 (游戏:骑士旅途的动画) 习题思路 代码示例 动画演示 ***18.33 (游戏:骑士旅途的动画) 为骑士旅途的问题编写一个程序,该程序应该允许用户将骑士放到任何一个起始正方形,并单击Solve按钮,用动画展示骑士沿着路径的移动&…

深度学习之表示学习 - 贪心逐层无监督预训练篇

引言 在人工智能的浩瀚星空中,深度学习以其强大的数据处理与模式识别能力,成为了一颗璀璨的明星。而表示学习,作为深度学习的核心基石之一,正引领着这一领域不断突破边界。表示学习旨在将原始数据转换为更加抽象、更有意义的特征…

leetcode第二十六题:删去有序数组的重复项

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 考虑 nums 的唯一元素的数量为 k ,你…

Rasa对话模型——做一个语言助手

1、Rasa模型 1.1 模型介绍 Rasa是一个用于构建对话 AI 的开源框架,主要用于开发聊天机器人和语音助手。Rasa 提供了自然语言理解(NLU)和对话管理(DM)功能,使开发者能够创建智能、交互式的对话系统。 1.2…

Eclipse 工作空间

Eclipse 工作空间 Eclipse 工作空间(Workspace)是 Eclipse IDE 中一个核心概念,它指的是一个用于组织和存储开发项目及相关文件的目录。在 Eclipse 中,所有开发活动都是围绕工作空间展开的。本文将详细介绍 Eclipse 工作空间的概念、配置、使用方法,以及如何通过优化工作…

Apache Iceberg 数据类型参考表

Apache Iceberg 概述-链接 Apache Iceberg 数据类型参考表 数据类型描述实例方法注意事项BOOLEAN布尔类型,表示真或假true, false用于条件判断,例如 WHERE is_active true。确保逻辑条件的正确性。INTEGER32位有符号整数42, -7可用于计算、聚合&#xf…

【系统架构设计师】专题:中间件技术

更多内容请见: 备考系统架构设计师-核心总结目录 文章目录 一、中间件概述二、中间件特点三、中间件的分类四、中间件产品介绍一、中间件概述 中间件(middleware) 是基础软件的一大类,属于可复用软件的范畴。顾名思义,中间件处在操作系统、网络和数据库之上,应用软件的下层…

着色器ShaderMask

说明 实现一个渐变进度条,要求: 颜色渐变的过程是循序渐进的,而不是看起来像是将渐变条逐渐拉长了。 效果 源码 // 渐变进度条Stack(children: [// 背景色板Container(width: 300,height: 8,decoration: BoxDecoration(borderRadius: Bord…

vue2知识汇总

vue2.x 0. 参考文档 https://cn.vuejs.org/v2/api/https://cn.vuejs.org/v2/guide/1. 发展历程 2014.2 诞生 2015.10 vue1.0发布 2016.4 vue2.0发布预览版, 10月出正式版本 2020.4 vue3.0发布预览版 9.18正式版本2. 概述 声明式渲染 --- 组件系统 ---…

ollama 部署教程(window、linux)

目录 一、官网 二、安装方式一:window10版本下载 三、安装方式二:linux版本docker 四、 模型库 五、运行模型 六、API服务 七、python调用 ollama库调用 langchain调用 requests调用 aiohttp调用 八、模型添加方式 1.线上pull 2.导入 GGU…

Parallels Desktop 20 for Mac 推出:完美兼容 macOS Sequoia 与 Win11 24H2

Parallels Desktop 20 for Mac 近日正式发布,这一新版本不仅全面支持 macOS Sequoia 和 Windows 11 24H2,还在企业版中引入了一个全新的管理门户。新版本针对 Windows、macOS 和 Linux 虚拟机进行了多项改进,其中最引人注目的当属 Parallels …

【AI写作】介绍 Docker 的基本概念和优势,以及在应用程序开发中的实际应用

【AI写作】介绍 Docker 的基本概念和优势,以及在应用程序开发中的实际应用 浅浅的玩一下这个 AI 写作,本内容全为 AI 生成,仅为 AI 观点,无作者本人的观点。 Docker是一个开源的容器化平台,它可以轻松地将应用程序及…

C++编程语言:基础设施:源文件和程序(Bjarne Stroustrup)

第15章 源文件和程序 (Source Files and Programs) 目录 15.1 单独编译(Separate Compilation) 15.2 链接(Linkage) 15.2.1 文件局部名(File-Local Names) 15.2.2 头文件(Header Files) 15.2.3 一次定义原则(The One-Definition Rule) 15.2.4 标准库头文件 1…

基于YOLOv8+LSTM的商超扶梯场景下行人安全行为姿态检测识别

基于YOLOv8LSTM的商超扶梯场景下行人安全行为姿态检测识别 手扶电梯 行为识别 可检测有人正常行走,有人 跌倒,有人逆行三种行为 跌倒检测 电梯跌倒 扶梯跌倒 人体行为检测 YOLOv8LSTM。 基于YOLOv8LSTM的商超扶梯场景下行人安全行为姿态检测识别&#xf…

STM32上实现FFT算法精准测量正弦波信号的幅值、频率和相位差(标准库)

在研究声音、电力或任何形式的波形时,我们常常需要穿过表面看本质。FFT(快速傅里叶变换)就是这样一种强大的工具,它能够揭示隐藏在复杂信号背后的频率成分。本文将带你走进FFT的世界,了解它是如何将时域信号转化为频域…

力扣(leetcode)每日一题 815 公交路线 (图的宽度优先遍历变种)

815. 公交路线 - 力扣(LeetCode) 题干 给你一个数组 routes ,表示一系列公交线路,其中每个 routes[i] 表示一条公交线路,第 i 辆公交车将会在上面循环行驶。 例如,路线 routes[0] [1, 5, 7] 表示第 0 辆…