4. Vue Router4 动态路由

在 Vue Router 4 中,动态路由是一种非常强大的功能,它允许我们根据不同的 URL 参数来渲染不同的组件或者同一组件的不同状态。这对于创建用户个人页面或者具有大量内容的应用来说非常有用。

基本用法

要创建一个动态路由,我们可以在路由的路径中添加一个冒号 :,后面跟上参数的名字。例如:

const routes = [{ path: '/user/:id', component: User }
]

在这个例子中,:id 就是一个路由参数。当我们访问 /user/1 的时候,User 组件就会被渲染出来,并且 this.$route.params.id 的值会是 '1'

动态路由匹配

Vue Router 4 提供了强大的动态路由匹配功能,可以让我们更灵活地处理路由参数。例如,我们可以使用正则表达式来限制路由参数的格式:

const routes = [{ path: '/user/:id(\\d+)', component: User }
]

在这个例子中,:id(\\d+) 表示 id 参数必须是数字。当我们访问 /user/abc 的时候,由于 abc 不是数字,所以不会匹配到 User 组件。

动态路由的参数传递

在 Vue Router 4 中,我们可以通过多种方式来传递路由参数。最常见的方式是在 path 中定义参数,然后在 URL 中传递。但是,我们也可以在导航的时候,通过 params 选项来传递参数:

router.push({ name: 'user', params: { id: '123' }})

在这个例子中,我们通过 name 选项来指定要导航到的路由,然后通过 params 选项来传递参数。这种方式的好处是,我们可以在不改变 URL 的情况下,传递任意类型的参数。

路由参数的响应式

在 Vue Router 4 中,路由参数是响应式的。也就是说,当我们在同一个路由内部改变参数的时候,对应的组件不会被重新创建,而是会复用。同时,组件内部可以通过 watch 来监听 $route 对象的变化,从而做出相应的动作。例如:

const User = {template: '<div>User {{ $route.params.id }}</div>',watch: {'$route' (to, from) {// 对路由变化作出响应...}}
}

在这个例子中,当我们从 /user/1 导航到 /user/2 的时候,User 组件会被复用,同时 $route 对象会发生变化,触发 watch 中的回调函数。

注意事项

在使用动态路由的时候,有一些需要注意的地方:

  1. 当路由参数变化的时候,对应的组件会被复用,而不是重新创建。这意味着组件的生命周期钩子不会被调用。如果我们需要在参数变化的时候做一些操作,可以通过 watch 来监听 $route 对象的变化。
  2. 在导航到新的路由的时候,我们可以通过 replace 选项来控制是否在浏览器的历史记录中创建新的记录。例如,router.push({ path: '/user/1', replace: true }) 会导航到 /user/1,但是不会在历史记录中创建新的记录。

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

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

相关文章

SSRF靶场

SSRF概述 ​ 强制服务器发送一个攻击者的请求 ​ 互联网上的很多web应用提供了从其他服务器&#xff08;也可以是本地)获取数据的功能。使用用户指定的URL&#xff0c;web应用可以获取图片&#xff08;载入图片&#xff09;、文件资源&#xff08;下载或读取)。如下图所示&…

【Blockchain】连接智能合约与现实世界的桥梁Chainlink

去中心化预言机试图实现依赖因果关系而不是个人关系的去信任和确定性结果。它以与区块链网络相同的方式实现这些结果&#xff0c;即在许多网络参与者之间分配信任。通过利用许多不同的数据源并实施不受单个实体控制的预言机系统&#xff0c;去中心化的预言机网络有可能为智能合…

Java集合-Collections与Arrays

Collections与Arrays 集合框架中的工具类&#xff1a;特点&#xff1a;该工具类中的方法都是静态的。 Collections&#xff1a;常见方法&#xff1a; 对list进行二分查找&#xff1a;前提该集合一定要有序。 int binarySearch(list,key); //必须根据元素自然顺序对列表进行升级…

阿里云优惠券使用方法图解_优惠券免费领取入口

2024年最新阿里云优惠代金券领取入口&#xff0c;阿里云服务器优惠代金券、域名代金券&#xff0c;在领券中心可以领取当前最新可用的满减代金券&#xff0c;阿里云百科aliyunbaike.com分享阿里云服务器代金券、领券中心、域名代金券领取、代金券查询及使用方法&#xff0c;可以…

第11章 数据仓库和数据智能知识点梳理

第11章 数据仓库和数据智能知识点梳理&#xff08;附带页码&#xff09; ◼ 数据仓库&#xff08;Data Warehouse&#xff0c;DW&#xff09;&#xff1a;始于 20 世纪 80 年代&#xff0c;发展于 20 世纪 90 年代&#xff0c;后与商务智能&#xff08;Business Inteligence,BI…

jenkins下载安装(mac)

下载官网 直接命令安装 Sample commands: Install the latest LTS version: brew install jenkins-ltsStart the Jenkins service: brew services start jenkins-ltsRestart the Jenkins service: brew services restart jenkins-ltsUpdate the Jenkins version: brew upgrade …

【Javascript】数据类型检测

文章目录 一、typeof1、描述2、示例 二、instanceof1、语法2、示例 三、Object.prototype.toString.call()1、描述2、语法3、示例4、通用判断方法 在JavaScript中&#xff0c;你可以用不同的方式检测数据类型。这是因为JavaScript是一种弱类型或动态语言&#xff0c;变量没有预…

Linux 安装KVM虚拟机

什么是KVM虚拟机&#xff1f; KVM 是 Kernel-based Virtual Machine 的缩写&#xff0c;是一种用于虚拟化的开源硬件虚拟化技术。它使用 Linux 内核的虚拟化模块&#xff0c;将物理服务器划分为多个虚拟机。KVM 允许虚拟机直接访问物理硬件资源,从而提供出色的性能和稳定性,同…

WARNING: No swap limit support——查看docker状态时提示警告

环境&#xff1a;Ubuntu 20.04 1、警告详情 执行命令 service docker status如下图 2、解决办法 2.1 修改文件 执行命令 vim /etc/default/grub在GRUB_CMDLINE_LINUX中追加cgroup_enablememory swapaccount1&#xff0c;如下&#xff1a; # If you change this file…

MyBatis 面试题(四)

1. MyBatis 中 Mapper 接口的实现原理是? MyBatis 中 Mapper 接口的实现原理主要基于 Java 的动态代理和反射机制。以下是 Mapper 接口实现原理的详细解释&#xff1a; Mapper 接口定义&#xff1a;首先&#xff0c;开发者需要定义一个 Mapper 接口&#xff0c;该接口中声明了…

【六】fastapi+vue前后端分离项目

前端代码 https://gitee.com/feiminjie/helloworldfront 后端代码 https://gitee.com/feiminjie/helloworld 整体效果 首页 用例管理页 用例详情页

GPT 浅析

GPT 浅析 文章目录 GPT 浅析GPT 1无监督预训练有监督微调任务相关的输入变换 GPT2GPT3 GPT 1 在模型架构上&#xff0c;GPT-1基于Transformer构造&#xff0c;这是因为与其他卷积神经网 络或者循环神经网络相比&#xff0c;Transformer提供了效率更高的方法来处理文本 中的长期…

几年前删除的照片如何恢复?5步操作,快速找回iPhone照片

“去年三月份参加了社区的志愿者活动拍了好几张照片&#xff0c;近期学校组织我申报市级优秀学生需要我的参加志愿者的照片当材料&#xff0c;但是照片在一年前就删掉了。删除的时间比较久&#xff0c;各位有没有什么方法可以恢复苹果手机的照片&#xff1f;” 在使用苹果手机的…

rk3588 安卓调试

rknn装上了android系统&#xff0c;用type-c usb连接上电脑&#xff0c;设备管理器发现了rk3588&#xff0c;但是Android Studio没有发现设备 后来怀疑是驱动没有安装&#xff0c;我用的驱动下载地址&#xff1a; 瑞芯微Rockchip驱动安装助手(适用于RK3308 RK3399等) Mcuzone…

使用Python实现集成学习算法:Bagging与Boosting

集成学习是一种机器学习方法&#xff0c;它通过结合多个弱学习器来构建一个强大的模型&#xff0c;从而提高预测的准确性和稳定性。在本文中&#xff0c;我们将介绍两种常见的集成学习算法&#xff1a;Bagging&#xff08;自举聚合&#xff09;和Boosting&#xff08;提升法&am…

还有同学开题报告没写吗?

引言 作为一名在软件技术领域深耕多年的专业人士&#xff0c;我不仅在软件开发和项目部署方面积累了丰富的实践经验&#xff0c;更以卓越的技术实力获得了&#x1f3c5;30项软件著作权证书的殊荣。这些成就不仅是对我的技术专长的肯定&#xff0c;也是对我的创新精神和专业承诺…

springboot 文件上传Linux环境报错

java.io.IOException: Malformed input or input contains unmappable characters: /data/upload_file/upload/2020/04/16/测试专用_20240416114011A001.pdf程序部署到Linux环境下&#xff0c;文件上传报错&#xff0c;这是因为服务器编码问题。 使用命令查看服务器编码&#x…

【智能算法】鸭群算法(DSA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2021年&#xff0c;Zhang等人受到自然界鸭群觅食行为启发&#xff0c;提出了鸭群算法&#xff08;Duck Swarm Algorithm, DSA&#xff09;。 2.算法原理 2.1算法思想 DSA基于自然界鸭群觅食过程&…

matplotlib手动调用默认配色

matplotlib 画图有个默认配色方案&#xff0c;在画不同图时会保持一致。如&#xff1a; import numpy as np import matplotlib.pyplot as plt# 图 1 数据 x np.arange(12).astype(np.float32) 1 y1 np.log(x) y2 1 / x y3 np.sin(x) # 图 2 数据 a np.random.randn(200…

十万栋BIM建筑同屏加载!AMRT3D引擎领跑,强力赋能数字孪生

AMRT3D数字孪生引擎https://www.amrt3d.com/#/ AMRT3D是让用户轻松搭建智慧城市、智慧工厂、CIM系统等类型应用的轻量化图形引擎&#xff0c;通过基于自主研发三维底层技术支持&#xff0c;可以让数字化、可视化项目轻松运行在Web等多平台。 它提供了百余种3D功能&#xff0c;…