update 修改删除tag方法 增加无参refreshPage
This commit is contained in:
parent
3b3fb80231
commit
a8ed066d8d
@ -3,8 +3,11 @@ import router from '@/router';
|
|||||||
import { TagView, RouteLocationRaw } from 'vue-router';
|
import { TagView, RouteLocationRaw } from 'vue-router';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
// 刷新当前tab页签
|
/**
|
||||||
async refreshPage(obj: TagView): Promise<void> {
|
* 刷新当前tab页签
|
||||||
|
* @param obj 标签对象
|
||||||
|
*/
|
||||||
|
async refreshPage(obj?: TagView): Promise<void> {
|
||||||
const { path, query, matched } = router.currentRoute.value;
|
const { path, query, matched } = router.currentRoute.value;
|
||||||
if (obj === undefined) {
|
if (obj === undefined) {
|
||||||
matched.forEach((m) => {
|
matched.forEach((m) => {
|
||||||
@ -15,11 +18,16 @@ export default {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// prettier-ignore
|
let query1: undefined | {} = {};
|
||||||
await useTagsViewStore().delCachedView(obj)
|
let path1: undefined | string = '';
|
||||||
|
if (obj) {
|
||||||
|
query1 = obj.query;
|
||||||
|
path1 = obj.path;
|
||||||
|
}
|
||||||
|
await useTagsViewStore().delCachedView(obj);
|
||||||
await router.replace({
|
await router.replace({
|
||||||
path: '/redirect' + obj.path,
|
path: '/redirect' + path1,
|
||||||
query: obj.query
|
query: query1
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
// 关闭当前tab页签,打开新页签
|
// 关闭当前tab页签,打开新页签
|
||||||
@ -68,7 +76,10 @@ export default {
|
|||||||
const obj = { path: url, query: { ...query, title } };
|
const obj = { path: url, query: { ...query, title } };
|
||||||
return router.push(obj);
|
return router.push(obj);
|
||||||
},
|
},
|
||||||
// 修改tab页签
|
/**
|
||||||
|
* 修改tab页签
|
||||||
|
* @param obj 标签对象
|
||||||
|
*/
|
||||||
updatePage(obj: TagView) {
|
updatePage(obj: TagView) {
|
||||||
return useTagsViewStore().updateVisitedView(obj);
|
return useTagsViewStore().updateVisitedView(obj);
|
||||||
}
|
}
|
||||||
|
@ -54,8 +54,11 @@ export const useTagsViewStore = defineStore('tagsView', () => {
|
|||||||
resolve([...visitedViews.value]);
|
resolve([...visitedViews.value]);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
const delCachedView = (view: TagView): Promise<string[]> => {
|
const delCachedView = (view?: TagView): Promise<string[]> => {
|
||||||
const viewName = view.name as string;
|
let viewName = '';
|
||||||
|
if (view) {
|
||||||
|
viewName = view.name as string;
|
||||||
|
}
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
const index = cachedViews.value.indexOf(viewName);
|
const index = cachedViews.value.indexOf(viewName);
|
||||||
index > -1 && cachedViews.value.splice(index, 1);
|
index > -1 && cachedViews.value.splice(index, 1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user