设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间02 现在时间02 缓存数据 你要知道这个世界上没有人会突然不爱你 只是你突然发现了而已

你要知道这个世界上没有人会突然不爱你 只是你突然发现了而已 -- 朗朗晴天

查看: 1281|回复: 3

vue如何通过params和query传值(刷新不丢失)

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:228
  • 打卡月天数:1
  • 打卡总奖励:3360
  • 最近打卡:2025-07-29 05:50:35
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
417
主题
387
精华
0
金钱
4608
积分
858
注册时间
2023-1-6
最后登录
2025-7-29

发表于 2023-5-17 20:59:38 | 显示全部楼层 |阅读模式
vue通过路由传值

在许多跳转的同时需要完成携带参数,并且在刷新的同时不丢失参数。
  1. $router
复制代码
:是路由操作对象,只写对象
  1. $route
复制代码
:路由信息对象,只读对象

一. 通过query传递参数刷新不丢失参数

在需要传值的页面:
  1. this.$router.push({
  2.    path: '/tasks',//通过path跳转
  3.    query: {
  4.             id : id,
  5.           formId : formId
  6.    }
  7. })
复制代码
设置的router:
  1. {
  2.   path: '/tasks',
  3.   name: 'tasks-detail',
  4.   component: () => import('@/views/todo/detail.vue')
  5. },
复制代码
在地址栏便会是这样的格式显示出参数,很像get请求的形式
220036i55ttk111re7t15l.png

通过在跳转的页面运用this.$route的方法得到传参
220037jy855vspezxseyzv.png

220037cgrqlhuvnb4vvq77.png

因为存放在地址栏所以刷新也会通过this.$route拿到。

二. 通过params传递参数刷新不丢失参数

如果要做到刷新不还能获取,其实也是在地址栏另一形式的存参在需要传值的页面:
  1. this.$router.push({
  2.    path : `/tasks/${item.id}/${item.formId}`,
  3. })
复制代码
设置的router:
  1. {
  2.   path: '/tasks/:id/:formId',
  3.   name: 'tasks-detail',
  4.   component: () => import('@/views/todo/detail.vue')
  5. },
复制代码
在地址栏便会是这样的格式显示出参数,一一对应
220037rvauzgxup6q73ibq.png

220037wmap5qj0ahdpm7pa.png

同样也刷新不会改变,如果是通过params传参的形式刷新参数便会丢失,类似下面这种
  1. path:'/tasks',
  2. params: {
  3.   id : item.id,
  4.   formId : item.formId
  5. }
复制代码
三. 同时使用params和query传递参数刷新不丢失参数

如果要做到刷新不还能获取,同样也是地址栏另一形式的存参在需要传值的页面:
  1. this.$router.push({
  2.      path: '/tasks/' + item.id,
  3.      query: {
  4.        formId : item.formId
  5.      },
  6. })
复制代码
设置的router:
  1. {
  2.   path: '/tasks/:taskId',
  3.   name: 'tasks-detail',
  4.   props: (route) => ({ ...route.query, ...route.params }),//可以运用props结合扩展运算符获取参数
  5.   component: () => import('@/views/todo/detail.vue')
  6. },
复制代码
在地址栏便会是这样的格式显示出参数
220037i50u8mrkk8jm5mwu.png

220037nzmb8lngbhkbh8zh.png

同样也刷新不会改变,地址栏更能看出结合版,这种混合运用利用props更方便接收值
220037ylvuj8ymj14vkibh.png


总的来说

1.如果需要做到刷新不丢失参数和值必须通过地址栏
2.query传参地址更像是get请求的格式
3.params如果需要刷新不丢是直接在path上对应形式传参,不能通过params的对象传参
4.结合使用可以通过props更好的接收参数
以上为个人经验,希望能给大家一个参考,也希望大家多多支持晓枫资讯。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

  • 打卡等级:即来则安
  • 打卡总天数:22
  • 打卡月天数:0
  • 打卡总奖励:280
  • 最近打卡:2025-04-13 12:20:05
等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
319
积分
50
注册时间
2023-4-3
最后登录
2025-4-13

发表于 2023-8-5 17:18:05 | 显示全部楼层
谢谢分享~~~~~
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
18
积分
16
注册时间
2022-12-29
最后登录
2022-12-29

发表于 2025-1-23 14:13:39 | 显示全部楼层
感谢楼主分享。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

  • 打卡等级:无名新人
  • 打卡总天数:1
  • 打卡月天数:0
  • 打卡总奖励:17
  • 最近打卡:2025-06-28 04:55:10
等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
29
积分
4
注册时间
2024-11-2
最后登录
2025-6-28

发表于 2025-4-22 21:35:40 | 显示全部楼层
顶顶更健康!!!
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼
3楼
4楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表