【Vue】Vue-Router(路由)

一、基本概念

  1. 路由(Route)
    • 路由表示一个映射关系,即 URL 路径到组件的映射。在 Vue-Router 中,一个路由对象通常包含两个主要部分:path(路径)和 component(组件)。
  2. 路由集合(Routes)
    • 路由集合是一组路由的集合,通常通过数组形式声明,在 Vue-Router 中被用来定义应用中所有的路由规则。
  3. 路由实例(Router)
    • 路由实例是 Vue-Router 的核心,它负责创建路由映射表并管理路由的跳转。通过 Vue-Router 的构造函数 new VueRouter() 创建路由实例,并传入路由集合(routes)等配置。

二、安装与配置

1、安装 Vue-Router

  • 在 Vue 项目中,首先需要安装 Vue-Router。可以使用 npm 或 yarn 进行安装,例如:npm install vue-router@4(注意:版本号可能会根据 Vue 的版本和个人需求有所不同)。

2、配置路由

  • 创建一个路由配置文件(如 router/index.js),在该文件中导入 Vue 和 Vue-Router,定义路由集合,并创建路由实例。
  • 示例代码:
import { createRouter, createWebHistory } from 'vue-router';  
import Home from '../views/Home.vue';  const routes = [  {  path: '/',  name: 'Home',  component: Home  },  // 其他路由...  
];  const router = createRouter({  history: createWebHistory(process.env.BASE_URL),  routes  
});  export default router;

3、将路由实例注入到 Vue 应用中

  • 在 Vue 应用的入口文件(如 main.jsmain.ts)中,导入路由实例,并使用 Vue.use(VueRouter)(Vue 3 中可能需要通过 createApp.use() 方法)来安装 Vue-Router,然后将路由实例传递给 Vue 应用实例

三、路由使用

1、声明式导航

  • 使用 <router-link> 组件来实现声明式导航,它会被渲染成一个 <a> 标签,但具有更好的路由跳转功能。<router-link>to 属性用于指定目标路由的路径或名称。
  • 示例代码:
<router-link to="/">首页</router-link>  
<router-link :to="{ name: 'About' }">关于</router-link>

2、编程式导航

  • 使用路由实例的 pushreplacego 方法来实现编程式导航。这些方法可以在 Vue 组件的 JavaScript 代码中调用,以实现更复杂的路由跳转逻辑。
  • 示例代码:
this.$router.push('/about');  
this.$router.replace({ name: 'Home' });  
this.$router.go(-1); // 后退一页

四、路由守卫

  • 路由守卫
    • Vue-Router 提供了全局守卫、路由独享守卫和组件内守卫等多种守卫方式,用于在路由跳转前后执行特定的逻辑,如权限校验、页面标题设置等。
    • 示例代码(全局前置守卫):
router.beforeEach((to, from, next) => {  // 逻辑处理...  next(); // 确保调用 next 方法,否则钩子就不会被解析  
});

五、路由模式

  • Hash 模式
    • 使用 URL 的 hash 来模拟一个完整的 URL,于是当 URL 改变时,页面不会重新加载。该模式默认启用,且不需要服务器配置。
  • History 模式
    • 利用 HTML5 History Interface 来完成 URL 跳转而无需重新加载页面。该模式需要服务器配置,以确保用户直接访问(如通过书签访问)深度链接时,服务器能返回正确的文件(通常是 index.html)。

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

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

相关文章

java面向对象总结

java面向对象篇到这里就已经结束了&#xff0c;有什么不懂的地方可以逐一进行重新观看。希望大家能够从入门到起飞。 Java面向对象基础篇综合训练&#xff08;附带全套源代码及逐语句分析&#xff09;-&#xff1e;基于javabeen Java面向对象进阶篇综合训练&#xff08;附带全…

2024 Java 高分面试宝典 一站式搞定技术面

前言 每年9月和10月&#xff0c;被业界称为“金九银十”&#xff0c;这是人才市场一年中最活跃的时期。此时&#xff0c;企业为了来年的业务扩展&#xff0c;纷纷加大招聘力度&#xff0c;空缺岗位众多&#xff0c;招聘需求集中。同时&#xff0c;初秋的招聘活动也避开酷暑&am…

操作系统:高级IO

高级IO 1.关于IO IO的基本类型&#xff1a; I代表输入(Input): 从外部设备或来源&#xff08;如键盘、鼠标、文件、网络&#xff09;读取数据到计算机中。示例&#xff1a;用户键入的文本、从文件读取的数据、从网络接收到的数据包。 O代表输出(Output): 将计算机处理后的数据发…

git 版本回退-idea

1、选中项目&#xff0c;右键&#xff0c;打开 git历史提交记录 2、选中想要回退的版本&#xff0c;选择 hard&#xff08;不保留版本记录&#xff09; 3、最终选择强制提交&#xff08;必须强制&#xff09; OK&#xff0c;搞定

OpenCV 图像预处理—图像金字塔

文章目录 相关概念高斯金字塔拉普拉斯金字塔应用 构建高斯金字塔为什么要对当前层进行模糊&#xff1f;1. 平滑处理2. 减少混叠&#xff08;Aliasing&#xff09;3. 多尺度表示4. 图像降采样 举个栗子创建高斯金字塔和拉普拉斯金字塔&#xff0c;并用拉普拉斯金字塔恢复图像 相…

【PyTorch】基于YOLO的多目标检测项目(二)

【PyTorch】基于YOLO的多目标检测项目&#xff08;一&#xff09; 【PyTorch】基于YOLO的多目标检测项目&#xff08;二&#xff09; YOLO-v3网络由跨距为2的卷积层、跳跃连接层和上采样层组成&#xff0c;没有池化层。网络接收一幅416 * 416的图像作为输入&#xff0c;并提供三…

docker compose build 怎么才能只构建其中一个服务的镜像

要使用 Docker Compose 只构建其中一个特定服务的镜像&#xff0c;你可以使用以下命令&#xff1a; docker-compose build <service_name>其中 <service_name> 是你想要构建的服务名称&#xff0c;这个名称应该与你的 docker-compose.yml 文件中定义的服务名称相匹…

C++从入门到入土(三)--6个默认成员函数

目录 前言 什么是默认成员函数 构造函数 概念 特性 析构函数 概念 特性 拷贝构造函数 概念 特性 赋值运算符重载 特性 前言 很久没有更新文章了&#xff0c;最近把类和对象相关的知识重新回顾了一遍&#xff0c;打算从今天开始继续更新C从入门到入土系列。前面我们…

DVWA中SQL注入漏洞细说

SQL注入是一种安全漏洞&#xff0c;它允许攻击者通过影响Web应用程序的后端数据库。攻击者可以通过在输入字段中插入恶意SQL代码来执行非授权查询&#xff0c;从而获取或修改数据。 在开始启动SQL注入之前我们先将DVWA的安全等级调整到Low 1、我们在SQL Injection中输入 1 and…

Linux文件恢复

很麻烦 一般还是小心最好 特别恢复的时候 可能不能选择某个文件夹去扫描恢复 所以 删除的时候 用rm -i代替rm 一定小心 以及 探索下linux的垃圾箱机制 注意 一定要恢复到不同文件夹 省的出问题 法1 系统自带工具 debugfs 但是好像不能重启&#xff1f; testdisk 1、安装 …

Flink笔记整理(四)

Flink笔记整理&#xff08;四&#xff09; 文章目录 Flink笔记整理&#xff08;四&#xff09;六、Flink中的时间和窗口6.1 窗口&#xff08;Window&#xff09;窗口的概念窗口的分类窗口API概览窗口分配器窗口函数&#xff08;Window Functions&#xff09; 6.2 时间语义&…

MySQL的库操作和表操作

文章目录 MYSQLSQL语句分类服务器&#xff0c;数据库和表的关系 库操作表操作 MYSQL SQL语句分类 DDL【data definition language】 数据定义语言&#xff0c;用来维护存储数据的结构代表指令: create, drop, alterDML【data manipulation language】 数据操纵语言&#xff0…

关键路径算法(Critical Path)

这个算法《算法导论》中并没有提及&#xff0c;很多书和博客说的有点奇怪&#xff0c;所以写本文作为笔记。 关键路径是什么 关键路径的定义非常简单&#xff1a;就是一个图中&#xff0c;权值之和最大的路径就是关键路径。 那么就可以知道关键路径不唯一。 为什么有关键路…

安装 moleculeSTM 踩坑日记

“学习 LLM &#xff0c;在大模型时代为自己存张船票”。 相信很多人都有这样的想法。那么&#xff0c;在 AI for science 领域&#xff0c;哪些 LLM 模型值得一试呢&#xff1f; 笔者认为&#xff1a; LLM 直接预测 SMILES 性质 or 直接生成 SMILES 的技术路线是行不通的。因…

搭建DNS正向解析,反向解析+搭建DNS主从架构+搭建DNS多区域+时间同步

主要在局域网中配置&#xff0c;不存在外网 正向解析&#xff1a;域名解析为IP named.conf 解决权限 named.rfc1912.zones 解决解析方式 环境准备&#xff1a;三台机器都做下面的操作 基础配置&#xff1a;网络配置&#xff0c;关闭安全架构&#xff0c;关闭防火墙&#x…

Redis常用命令第二版

目录 1. 连接 Redis 客户端 1.1 连接实例1&#xff1a; 1.2 连接实例2&#xff1a; 1.3 极速版查看键值命令&#xff1a; 1.4 获取 Redis 配置&#xff1a; 2. 启动 Redis 实例 2.1 启动实例1&#xff1a; 2.2 启动实例2&#xff1a; 2.3 启动253的实例&#xff1a; …

Linux相关指令

1.查看手册 man 3 free 2.调试 ①gcc link.c -g ②gbd a.out ③(gbd)r 运行 ④(gbd)q 退出 3.gcc demo8.c -lpthread -o demo8 //该指令将demo.c生成的a.out文件命名为demo8 。其中的-lpthread不是必须的&#xff0c;只有用到该库才输入加上。 4…/a.out 10 >>test.ret.t…

使用langchain4j调用大模型写个聊天助手

LangChain4j是一款基于Java的高效、灵活的AI大模型应用框架&#xff0c;专为简化Java应用程序与LLMs&#xff08;大语言模型&#xff09;的集成而设计。它提供统一API和模块化设计&#xff0c;支持多种LLM提供商和嵌入模型&#xff0c;以及丰富的工具箱&#xff0c;如AI服务和R…

光伏混合储能直流微网直流母线电压下垂控制MATLAB仿真

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 模型简介 此模型以混合储能系统为研究对象&#xff0c;采用基于关联参数SOC的改进下垂控制策略&#xff0c;将初始下垂系数与储能单元SOC的n次幂的比值作为现行下垂系数&#xff0c;通过改变n值&#xff0c;…