vue3+vite模版框架 tabs右键刷新时丢失路由参数

问题:

标题栏的tabs的右键:刷新时,没有保存上一个页面传递过来的参数

分析:

TagView.vue刷新事件

复制代码
function refreshSelectedTag(view: TagView) {
  console.log('|--执行刷新', view)
  tagsViewStore.delCachedView(view);
  const {fullPath} = view;
  nextTick(() => {
    router.replace({path: "/redirect" + fullPath});
  });
}

刷新获取到当前路由,没有把route里的路由参数对象拿出来,query

解决:

首先添加tag时,把query也添加到tag view里

//src\layout\components\TagsView.vue

function addTags() {

if (route.meta.title) {

tagsViewStore.addView({

name: route.name as string,

title: route.meta.title,

path: route.path,

fullPath: route.fullPath,

affix: route.meta?.affix,

keepAlive: route.meta?.keepAlive,

query: route.query,

});

}

}

执行右键: 【刷新】事件把query拿回来
复制代码
function refreshSelectedTag(view: TagView) {
  console.log('|--执行刷新', view)
  tagsViewStore.delCachedView(view);
  const {fullPath, query} = view;
  nextTick(() => {
    router.replace({path: "/redirect" + fullPath, query});
  });
}
在需要刷新:xx.vue页面

在onActivate地方重置获取一下,再执行刷新事件并请求最新的数据

复制代码
onActivated(() => { //刷新时候保存query
  planInfor.value.id = route.query.id
  getDetailRequest()
})
相关推荐
toooooop818 分钟前
Vuex 中 state、mutations 和 actions 的原理和写法
前端·javascript·uni-app
y***866925 分钟前
前端CSS-in-JS方案
前端·javascript·css
暖木生晖31 分钟前
APIs之WEB API的基本认知是什么?
前端·dom·dom树·web apis
华仔啊31 分钟前
你真的懂递归吗?没那么复杂,但也没那么简单
前端·javascript
火星数据-Tina35 分钟前
低成本搭建体育数据中台:一套 API 如何同时支撑比分网与 App?
java·前端·websocket
yddddddy38 分钟前
深入浅出前端路由:从概念到实战
前端
林_xi1 小时前
uniapp使用@uni-ku/root插件实现全局组件
前端·uni-app
一个处女座的程序猿O(∩_∩)O1 小时前
UniApp 生命周期全解析:从应用到页面,再到组件的完美协奏曲
前端·uni-app
龙颜1 小时前
从0-1封装一个React组件
前端·react.js
空空kkk2 小时前
SpringMVC——异常
java·前端·javascript