From a8ed066d8d02a42a0d997801a6b72ad0cd5806ae Mon Sep 17 00:00:00 2001 From: LiuHao Date: Tue, 20 Jun 2023 18:57:27 +0800 Subject: [PATCH] =?UTF-8?q?update=20=E4=BF=AE=E6=94=B9=E5=88=A0=E9=99=A4ta?= =?UTF-8?q?g=E6=96=B9=E6=B3=95=20=E5=A2=9E=E5=8A=A0=E6=97=A0=E5=8F=82refre?= =?UTF-8?q?shPage?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/plugins/tab.ts | 25 ++++++++++++++++++------- src/store/modules/tagsView.ts | 7 +++++-- 2 files changed, 23 insertions(+), 9 deletions(-) diff --git a/src/plugins/tab.ts b/src/plugins/tab.ts index 1c0ab7a..d730aab 100644 --- a/src/plugins/tab.ts +++ b/src/plugins/tab.ts @@ -3,8 +3,11 @@ import router from '@/router'; import { TagView, RouteLocationRaw } from 'vue-router'; export default { - // 刷新当前tab页签 - async refreshPage(obj: TagView): Promise { + /** + * 刷新当前tab页签 + * @param obj 标签对象 + */ + async refreshPage(obj?: TagView): Promise { const { path, query, matched } = router.currentRoute.value; if (obj === undefined) { matched.forEach((m) => { @@ -15,11 +18,16 @@ export default { } }); } - // prettier-ignore - await useTagsViewStore().delCachedView(obj) + let query1: undefined | {} = {}; + let path1: undefined | string = ''; + if (obj) { + query1 = obj.query; + path1 = obj.path; + } + await useTagsViewStore().delCachedView(obj); await router.replace({ - path: '/redirect' + obj.path, - query: obj.query + path: '/redirect' + path1, + query: query1 }); }, // 关闭当前tab页签,打开新页签 @@ -68,7 +76,10 @@ export default { const obj = { path: url, query: { ...query, title } }; return router.push(obj); }, - // 修改tab页签 + /** + * 修改tab页签 + * @param obj 标签对象 + */ updatePage(obj: TagView) { return useTagsViewStore().updateVisitedView(obj); } diff --git a/src/store/modules/tagsView.ts b/src/store/modules/tagsView.ts index 064e4ee..cd065d1 100644 --- a/src/store/modules/tagsView.ts +++ b/src/store/modules/tagsView.ts @@ -54,8 +54,11 @@ export const useTagsViewStore = defineStore('tagsView', () => { resolve([...visitedViews.value]); }); }; - const delCachedView = (view: TagView): Promise => { - const viewName = view.name as string; + const delCachedView = (view?: TagView): Promise => { + let viewName = ''; + if (view) { + viewName = view.name as string; + } return new Promise((resolve) => { const index = cachedViews.value.indexOf(viewName); index > -1 && cachedViews.value.splice(index, 1);