From 9dd7bf89909a0473ed02a7f1df7442973dd96c1e Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期三, 20 十一月 2024 11:25:51 +0800 Subject: [PATCH] fix 修复 手动登出与token过期登出跳转行为不一致问题 --- src/permission.ts | 14 ++++++++------ 1 files changed, 8 insertions(+), 6 deletions(-) diff --git a/src/permission.ts b/src/permission.ts index c819ff4..125438b 100644 --- a/src/permission.ts +++ b/src/permission.ts @@ -15,13 +15,13 @@ router.beforeEach(async (to, from, next) => { NProgress.start(); if (getToken()) { - to.meta.title && useSettingsStore().setTitle(to.meta.title as string); + to.meta.title && useSettingsStore().setTitle(to.meta.title); /* has token*/ if (to.path === '/login') { next({ path: '/' }); NProgress.done(); - } else if (whiteList.indexOf(to.path) !== -1) { - next() + } else if (whiteList.indexOf(to.path as string) !== -1) { + next(); } else { if (useUserStore().roles.length === 0) { isRelogin.show = true; @@ -40,7 +40,8 @@ router.addRoute(route); // 鍔ㄦ�佹坊鍔犲彲璁块棶璺敱琛� } }); - next({ ...to, replace: true }); // hack鏂规硶 纭繚addRoutes宸插畬鎴� + // @ts-ignore + next({ path: to.path, replace: true, params: to.params, query: to.query, hash: to.hash, name: to.name as string }); // hack鏂规硶 纭繚addRoutes宸插畬鎴� } } else { next(); @@ -48,11 +49,12 @@ } } else { // 娌℃湁token - if (whiteList.indexOf(to.path) !== -1) { + if (whiteList.indexOf(to.path as string) !== -1) { // 鍦ㄥ厤鐧诲綍鐧藉悕鍗曪紝鐩存帴杩涘叆 next(); } else { - next(`/login?redirect=${to.fullPath}`); // 鍚﹀垯鍏ㄩ儴閲嶅畾鍚戝埌鐧诲綍椤� + const redirect = encodeURIComponent(to.fullPath || '/'); + next(`/login?redirect=${redirect}`); // 鍚﹀垯鍏ㄩ儴閲嶅畾鍚戝埌鐧诲綍椤� NProgress.done(); } } -- Gitblit v1.9.3