Vue-router 路由间参数传递看完让你明明白白!

news2024/9/24 7:18:49

目录

  • 概述
  • 路由传参的两大载体分类
    • 声明式路由 【router-link 】
    • 编程式路由 【this.$router.push()】
  • 传参的方式
    • 1. 通过 params 传递参数
      • 配置路由参数字段占位(编程式路由实现)
      • 配置路由参数字段占位(声明式路由实现)
      • 无需配置路由参数字段占位(编程式路由实现)
      • 无需配置路由参数字段占位(声明式路由实现)
    • 2. 通过 query 传递参数
      • 通过router-link 传递 query 参数
      • 通过 编程式路由 传递 query 参数
    • 3.使用 props 属性代理传递参数
    • 补充点

概述

Vue- routrer,页面路由跳转时,携带参数传递 并拿取传递过来的参数,本文将详细讲解 Vue router传递参数的多种方式;
如果你还不了解 Vuerouter 基本使用及配置请通过下面传送门,了解vue router 路由的基本配置及使用
传送门去了解 Vue-router

路由传参的两大载体分类

声明式路由 【router-link 】

编程式路由 【this.$router.push()】

传参的方式

1. 通过 params 传递参数

params参数传递也有两种方式:第一种就是在路由路径 path 后面 添加接收参数的字段占位传参,第二种 就是不需要配置占位字段也能传参

配置路由参数字段占位(编程式路由实现)

//路由中配置
  {
    path: '/datapage/:id',   //若id后面加?代表这个参数是可选非必传的,即使不传id也不会导致页面无法访问
    name: 'datapage',
    component: datapage,
    children: [],
  },

//页面中跳转
  this.$router.push({
      path: `/datapage/${"参数"}`,       //如果要是用 path 传参 必须使用字符串模板    
  });

//或
  this.$router.push({       //如果要是用 name 传参 就直接 携带一个 params 对象中包含参数  
      name: "datapage",
      params:{
          id:"参数字段"
      }
  });

//目标页面中,读取出参数
this.$route.params.id

配置路由参数字段占位(声明式路由实现)

<!-- routerlink   采用 字符串模板来进行传递参数 -->
 <router-link :to=" `/datapage/${123456}` ">跳转</router-link>
<!-- 或 使用命名路由-->
 <router-link :to="{  name:  'datapage',  params:  {  id:  789787  }  }">跳转</router-link>

无需配置路由参数字段占位(编程式路由实现)

  this.$router.push({       //如果未在路由中配置接收参数字段,还要传递 params 参数, 就只能必须使用 name 进行跳转
      name: "datapage",
      params:{
          id:"参数字段"
      }
  });
//目标页面中,读取出参数
this.$route.params.id

无需配置路由参数字段占位(声明式路由实现)

<!-- 未定义路由路径字段,就必须使用  name 跳转传参 -->
 <router-link :to="{  name:  'datapage',  params:  {  id:  789787  }  }">跳转</router-link>

**注明**

同样都是 params 传参 在路由路径中定义 字段接收占位 和不定义字段 接受的区别 是什么?
答:定义字段路径是因为 参数 是以 路径的形式跟在URL 后面的,这样一来,即使浏览器页面刷新了过后参数也不会丢失。反之如果未配置接收参数字段,虽然参数依然能够正常传递,参数在URL中也不会显示,但是当页面或者浏览器刷新后,当前页面携带过来的参数会造成丢失。

2. 通过 query 传递参数

通过router-link 传递 query 参数

   <!-- 通过path 在路径后面跟 ? 加上参数字段名 -->
  <router-link :to="`/datapage?id=${'我是query传递的参数'}`">跳转</router-link>
          <!-- 或者 使用 命名路由传参 ,直接跟一个 query 对象携带参数-->
  <router-link :to="{ name: 'datapage', query: { id: '参数' } }">跳转</router-link>
          <!-- 还可以使用 path 对象 传参-->
  <router-link :to="{ path: '/datapage', query: { id: '参数66' } }">跳转</router-link>

在这里插入图片描述

通过 编程式路由 传递 query 参数

 this.$router.push({
     name: "datapage",
     query: {
         id: "我叫蜘蛛侠"
     }
 });


this.$router.push({
     path: "/datapage",
     query: {
         id: "我叫蜘蛛侠"
     }
 });
//页面中读取数据
this.$route.query.id

**注明**

query 方式传参,无需在路由配置文件中配置参数占位,参数是以 ?id 跟在url 后面的,页面刷新后,参数也不会丢失

补充说明:

如果 query 传递的参数是数组或者对象,地址栏中的参数会被转换成 [object Object] ,页面刷新后,读取不到参数值, 这里建议在传递 数组或对象的参数前,通过 JSON.stringify() 对数据进行序列化处理,目标页面拿到参数后,再进行反序列化即可。

3.使用 props 属性代理传递参数

前言:
有时候,当我们传递页面的数据过多的时候,目标页面内会出现大量的 this.$route.query 或者 this.$route.params 进行参数解构,还可能出现 多项 计算属性解构,这样页面会显得代码很冗杂
所以这时候 就可以使用 props 代理接收参数

在目标页面中定义好 Props 及要接收的参数名

<template>
  <div>
    <h1>{{ id }}</h1>
    <h1>{{ name }}</h1>
    <h1>{{ title }}</h1>
  </div>
</template>

<script>
export default {
  data() {
    return {

    }
  },
  props: ["id", "name", "title"],
}
</script>

在路由配置中

{
    path: '/datapage',
    name: 'datapage',
    component: datapage,
    children: [],

    // 第一种方式
    // props: { id: 1, name: "张三", title: "标题" }    直接给props 赋值,这时候的值是写死的静态数据
    // 第二种方式
    // props:true                          //如果props 设置为true 时,则会默认把props,映射到  params 参数上。

    //那么如果,我既要接收params 参数又要 接收 query  参数,通过 props 应该怎么实现呢?

    // 第三种方式  props 是一个函数   接收一个参数  可以拿到整个 route 实例对象,所有的 params  和 query  参数都可以在实例上拿取到

   props(route) {
      console.log(route);
      const { a } = route.params
      const { names } = route.params
      const { titles } = route.query
      return { id: a, name: names, title: titles }          //拿取到对应的值后,再整合到相应的字段格式上,返回数据
    }
  },

在这里插入图片描述

补充点

如果有这么一个需求,在我通过路由传递参数到目标页面的时候,我的目标页面需要对这个参数向后端进行请求校验,查看是否合法,也就是说,需要在路由传递参数的时候开启异步任务。

路由跳转时,传递的参数
在这里插入图片描述

<template>
  <div>
    <h1>{{ id }}</h1>
    <h1>{{ name }}</h1>
    <h1>{{ title }}</h1>
  </div>
</template>

<script>


export default {
  data() {
    return {
      name: '',    //假设我需要对传递过来的name 参数进行加工,校验处理,首先我们把,原本props 接收name 的参数,拿走,定义到data 中来。
    }
  },
  props: ["id", "title"],
  watch: {         //然后,采用  watch 数据监视,监视每一次路由传递参数的变化,并且能够拿到参数
    $route: {
      immediate: true,
      deep: true,
      handler(route) {
        setTimeout(() => {      //开启异步任务,对某一条数据进行加工处理。
          this.name = route.params.name + '____校验完成';
        }, 3000)
      }
    }
  },
}
</script>

点我了解watch 数据监视
在这里插入图片描述

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

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

相关文章

Spring框架(四):Spring命名空间和配置标签

Spring框架&#xff08;四&#xff09;&#xff1a;Spring命名空间和配置标签命名空间介绍配置标签Beans标签DemoImport标签Demoalias标签的Demo和Debug痛定思痛&#xff0c;主要问题出现在自己雀氏不熟悉框架基础、一些面试题&#xff0c;以及sql的使用淡忘了。本章节的开始是…

剩余内存无法满足申请时,系统会怎么做?

文章目录前言内存的分配机制回收可回收内存的类型如何在保证系统性能前提下回收内存可回收类型角度: 调整文件页回收倾向回收的方式角度: 尽早触发kswapd内核线程从计算机CPU架构角度: 采用NUMA如何保护进程不被OOM杀掉总结前言 当我们向操作系统申请内存时候,是否有想过一个问…

Bootstrap页面整合(十二)

首先引入bootstrap&#xff1a; 复制导航条代码&#xff1a; 修改导航条&#xff1a; 删除 改完的导航条&#xff1a; <!--导航条--> <nav class"navbar navbar-inverse"><div class"container-fluid"><!--屏幕自适应的--><d…

【吴恩达机器学习笔记】十、支持向量机

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?spm1011.2415.3001.5343 &#x1f4e3;专栏定位&#xff1a;为学习吴恩达机器学习视频的同学提供的随堂笔记。 &#x1f4da;专栏简介&#xff1a;在这个专栏&#xff0c;我将整理吴恩达机器学习视频的所有内容的笔记&…

神经气体网络(NGN)和不断增长的神经气体网络(GNGN)研究(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

[附源码]计算机毕业设计springboot影评网站系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Python案例实战,gopup模块,Python3行代码就能获取海量数据

前言 今天给大家分享一个三行代码就能获取海量数据 包含了有指数数据、宏观经济数据、新经济数据、微博KOL数据、信息数据、生活数据、疫情数据等。 开发工具 Python版本&#xff1a; 3.6.4 相关模块&#xff1a; gopup模块 环境搭建 安装Python并添加到环境变量&#…

Linux权限管理(umask、粘滞位)

目录 Linux权限管理 文件访问权限的相关设置方法 目录的权限 umask 粘滞位 Linux下有两种用户&#xff1a;超级用户&#xff08;root&#xff09;、普通用户。 超级用户&#xff1a;可以再linux系统下做任何事情&#xff0c;不受限制 普通用户&#xff1a;在linux下做有限…

闲鱼话术,必须收藏

今天分享&#xff1a;闲鱼卖货&#xff0c;常用的客服话术。建议收藏 很多学员&#xff0c;货也上了&#xff0c;有人咨询的时候忽然手忙脚乱&#xff0c;懵啊&#xff0c;怎么感觉没人问期待有人问&#xff0c;有人问&#xff0c;自己啥也说不出来了呢?哈哈&#xff0c;不知…

【BOOST C++ 19 应用库】(6)序列数据封装和优化

一、说明 用于优化的包装函数&#xff1a;本节介绍包装函数以优化序列化过程。这些函数标记对象以允许 Boost.Serialization 应用某些优化技术。 二、示范和代码 示例 64.14。在没有包装函数的情况下序列化数组 #include <boost/archive/text_oarchive.hpp> #include &…

[附源码]计算机毕业设计springboot医院门诊管理信息系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

SpringBoot中使用MySQL存用户信息, 日志的使用

SpringBoot中使用MySQL存用户信息 UserController类 package com.tedu.secboot.controller; import com.tarena.mnmp.api.SendParam; import com.tedu.secboot.entity.User; import com.tedu.secboot.util.DBUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory;…

flink教程(2)-source- sink

一、flink可识别的source分类 Sources are where your program reads its input from. You can attach a source to your program by using StreamExecutionEnvironment.addSource(sourceFunction). Flink comes with a number of pre-implemented source functions, but you c…

[附源码]计算机毕业设计游戏商城平台论文Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

[附源码]计算机毕业设计springboot线上评分分享平台

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【Android App】人脸识别中OpenCV根据人脸估算性别和年龄实战(附源码和演示 超详细)

需要源码请点赞关注收藏后评论区留言私信~~~ 人脸蕴含的信息量巨大&#xff0c;不管是青春还是年少&#xff0c;还是老年沧桑&#xff0c;都能体现出来&#xff0c;不过从人脸估算年龄估算年龄全凭经验&#xff0c;毕竟计算机无法根据固定框架判断年龄&#xff0c;那么计算机的…

ZYNQ之FPGA学习----IIC协议驱动模块仿真实验

1 IIC通信协议简介 IIC通信协议基础知识学习&#xff1a;硬件设计基础----通信协议IIC 2 实验任务 设计IIC驱动模块&#xff0c;并进行仿真验证&#xff0c;观察仿真波形 3 实验设计 3.1 创建工程 新建工程&#xff0c;操作如图所示&#xff1a; 输入工程名和路径&#x…

C++I/O流详解

目录 一&#xff0c;引入 二&#xff0c;C中的输入输出 1&#xff0c;输入输出流分类 2&#xff0c;I/O流类的安全性和可扩展性 (1)I/O流类的安全性 (2)I/O流类的扩展性 三&#xff0c;流类库简介 1&#xff0c;I/O流类库 2&#xff0c;缓冲区类 四&#xff0c;标准输…

python入门基础

1 变量和简单数据类型 变量命名格式&#xff1a;变量名 “赋值” 1.1 变量使用规范 使用变量时&#xff0c;需要遵守一些规则。违反这些规则将引发错误。 ~变量名只能包含数字、字母、下划线。变量名不能以数字开头以及不能包含空格。 ~变量名不能将Python保留字和函数名…

SpringColud——Eureka注册中心

目录 1、SpringColud概述 1.1、什么是微服务 1.2、什么是SpringColud&#xff1f; 1.3、SpringColud的特点 2、SpringColud环境准备 2.1、创建父工程 2.2、修改pom.xml文件 2.3、服务提供者——创建子工程 2.4、编写启动类 2.5、编写User类 2.6、编写UserMapper接口…