Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
basic-vue-admin
概览
概览
详情
活动
周期分析
版本库
存储库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
Basic
basic-vue-admin
Commits
cc46935a
提交
cc46935a
authored
8月 16, 2021
作者:
无木
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: always refresh userinfo when page reload
每次刷新整个页面时都从接口更新用户信息
上级
53e79a2d
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
12 行增加
和
2 行删除
+12
-2
permissionGuard.ts
src/router/guard/permissionGuard.ts
+5
-2
user.ts
src/store/modules/user.ts
+7
-0
没有找到文件。
src/router/guard/permissionGuard.ts
浏览文件 @
cc46935a
...
...
@@ -67,10 +67,14 @@ export function createPermissionGuard(router: Router) {
to
.
fullPath
!==
(
userStore
.
getUserInfo
.
homePath
||
PageEnum
.
BASE_HOME
)
)
{
next
(
userStore
.
getUserInfo
.
homePath
||
PageEnum
.
BASE_HOME
);
console
.
log
({
from
,
to
});
return
;
}
// get userinfo while last fetch time is empty
if
(
userStore
.
getLastUpdateTime
===
0
)
{
await
userStore
.
getUserInfoAction
();
}
if
(
permissionStore
.
getIsDynamicAddedRoute
)
{
next
();
return
;
...
...
@@ -88,7 +92,6 @@ export function createPermissionGuard(router: Router) {
if
(
to
.
name
===
PAGE_NOT_FOUND_ROUTE
.
name
)
{
// 动态添加路由后,此处应当重定向到fullPath,否则会加载404页面内容
// fix: 添加query以免丢失
next
({
path
:
to
.
fullPath
,
replace
:
true
,
query
:
to
.
query
});
}
else
{
const
redirectPath
=
(
from
.
query
.
redirect
||
to
.
path
)
as
string
;
...
...
src/store/modules/user.ts
浏览文件 @
cc46935a
...
...
@@ -20,6 +20,7 @@ interface UserState {
token
?:
string
;
roleList
:
RoleEnum
[];
sessionTimeout
?:
boolean
;
lastUpdateTime
:
number
;
}
export
const
useUserStore
=
defineStore
({
...
...
@@ -33,6 +34,8 @@ export const useUserStore = defineStore({
roleList
:
[],
// Whether the login expired
sessionTimeout
:
false
,
// Last fetch time
lastUpdateTime
:
0
,
}),
getters
:
{
getUserInfo
():
UserInfo
{
...
...
@@ -47,6 +50,9 @@ export const useUserStore = defineStore({
getSessionTimeout
():
boolean
{
return
!!
this
.
sessionTimeout
;
},
getLastUpdateTime
():
number
{
return
this
.
lastUpdateTime
;
},
},
actions
:
{
setToken
(
info
:
string
|
undefined
)
{
...
...
@@ -59,6 +65,7 @@ export const useUserStore = defineStore({
},
setUserInfo
(
info
:
UserInfo
)
{
this
.
userInfo
=
info
;
this
.
lastUpdateTime
=
new
Date
().
getTime
();
setAuthCache
(
USER_INFO_KEY
,
info
);
},
setSessionTimeout
(
flag
:
boolean
)
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论