解决vue3 路由query传参刷新后数据丢失的问题

前言:在页面刷新的时候,路由query数据会被清空,网上很多方法说query传参可以实现,反正我是没有实现

思路:将数据保存到本地,通过 " ?" 进行判断是否有数据,页面销毁的时候删除本地的数据

有数据就保存到本地

无数据就获取本地的数据

布置:

1.父组件

const sampleDetailClick = (routerId) => {

router.push({

path: '/informationEntry/specimenDetail',

query: { routerId },

});

};

2.封装公共的处理方法,方便后期使用

export function initRequest(path:any) {

let url = window.location.href.split("?");

if (url[1]) {

localStorage.setItem(url[0], url[1])

const paramsObj = stringToObject(url[1]);

return { isParams: true, paramsObj }

} else{

let params = localStorage.getItem(url[0]) || '';

const newUrl = window.location.origin + window.location.pathname + '?' + params;

window.history.replaceState({}, '', newUrl);

const paramsObj = stringToObject(params);

return { isParams: false, paramsObj }

}

}

引入

复制代码
import { initRequest } from '@/utils/utils.ts'

3.在子组件里面使用

复制代码
import { reactive, ref, onMounted, onBeforeUnmount } from 'vue';
import { initRequest } from '@/utils/utils.ts'
const route = useRoute();
let { id } = route.query;

let currentUrl = window.location.href.split("?");
onMounted(() => {

  const obj = initRequest()
  if (obj) ({ id } = obj.paramsObj);
  openAddModal();  //获取详情
})
onBeforeUnmount(() => { localStorage.removeItem(currentUrl[0]); })

4.刷新验证功能,在本地里面查看

相关推荐
GISer_Jing3 小时前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程
AI进化营-智能译站3 小时前
ROS2 C++开发系列14-Lambda表达式处理传感器数据流|文件IO保存机器人实验日志
开发语言·c++·ai·机器人
itzixiao3 小时前
L1-067 洛希极限(10分)[java][python]
java·开发语言·算法
IT_陈寒3 小时前
React的useEffect把我坑惨了,这些闭包陷阱真要命
前端·人工智能·后端
l1t4 小时前
DeepSeek总结的DuckDB anofox-forecast季节调整时间序列预测插件功能
开发语言·数据库
xyq20244 小时前
SVG 阴影
开发语言
前端之虎陈随易4 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·typescript·npm·node.js
好奇龙猫4 小时前
[大学院ーpython-base learning3: python and recommendation system ]
开发语言·python
澈2074 小时前
C++引用与指针:核心区别全解析
开发语言·数据结构·c++
沐知全栈开发4 小时前
Scala Iterator(迭代器)
开发语言