1111
This commit is contained in:
@@ -75,7 +75,7 @@ div {
|
||||
.foot {
|
||||
}
|
||||
|
||||
a {
|
||||
body a {
|
||||
color: #1e5494;
|
||||
margin: 0 5px;
|
||||
text-decoration: underline;
|
||||
|
||||
@@ -92,7 +92,7 @@ export class ApiService {
|
||||
this.initialized = true;
|
||||
}
|
||||
|
||||
public static async Request<T = unknown>(
|
||||
public static async Request<T = any>(
|
||||
method: HttpMethod,
|
||||
url: string,
|
||||
params: RequestParams = {}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
|
||||
export interface IResultData<T = unknown> {
|
||||
export interface IResultData<T = any> {
|
||||
code: number
|
||||
msg: string
|
||||
data?: T
|
||||
|
||||
@@ -87,22 +87,40 @@
|
||||
小G报时(18:33)
|
||||
</div>
|
||||
</div>
|
||||
<div v-for="(item, index) in areaData" :key="index">
|
||||
{{ index }} - {{ item.name }}
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
|
||||
|
||||
|
||||
//MessageExtend.ShowToast('success', '更新成功!')
|
||||
//MessageExtend.ShowToast('success', '更新成功!')
|
||||
//MessageExtend.NotifyList("success", ['获取装备',"获取物品"])
|
||||
definePageMeta({
|
||||
layout: layout.empty
|
||||
})
|
||||
|
||||
const areaData = ref<any>([]);
|
||||
|
||||
|
||||
|
||||
const Initialize = async (): Promise<void> => {
|
||||
var result = await PubService.GetMain();
|
||||
if (result.code == 0) {
|
||||
areaData.value = result.data?.area;
|
||||
|
||||
|
||||
}
|
||||
else {
|
||||
MessageExtend.ShowToast("fail", result.msg);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
// await navigateTo('/auth/login', { replace: true })
|
||||
onMounted(async () => {
|
||||
|
||||
const test = await LoginService.Test("dddd","dddd2");
|
||||
console.log(test);
|
||||
await Initialize();
|
||||
|
||||
//alert(1);
|
||||
})
|
||||
|
||||
@@ -1,23 +0,0 @@
|
||||
export class LoginService {
|
||||
/**
|
||||
* 登录接口
|
||||
* POST /Login/Login
|
||||
* 请求体: 登录请求参数
|
||||
* @param name 登录名/手机号
|
||||
* @param pwd 密码
|
||||
* @param code 验证码
|
||||
*/
|
||||
static async Login(name: string, pwd: string, code: string) {
|
||||
return ApiService.Request("post", "/Login/Login", { name, pwd, code });
|
||||
}
|
||||
|
||||
/**
|
||||
* 测试接口
|
||||
* GET /Login/Test
|
||||
* @param name 测试名
|
||||
* @param ttt 测试2
|
||||
*/
|
||||
static async Test(name: string, ttt: string) {
|
||||
return ApiService.Request("get", "/Login/Test", { name, ttt });
|
||||
}
|
||||
}
|
||||
@@ -3,72 +3,58 @@
|
||||
* 管理用户登录信息、Token等核心状态
|
||||
*/
|
||||
import { defineStore } from 'pinia'
|
||||
import type { IUserInfo } from '~/types/user'
|
||||
|
||||
// 仓库命名规范:use+业务域+Store
|
||||
export const useUserStore = defineStore('user', {
|
||||
// 1. 原始状态:仅存基础数据,不做任何计算、判断
|
||||
state: () => ({
|
||||
userInfo: null as IUserInfo | null,
|
||||
state: () => ({
|
||||
token: '',
|
||||
isLoading: false as boolean
|
||||
refToken:"",
|
||||
sid:""
|
||||
}),
|
||||
|
||||
// 2. 只读计算属性:封装派生逻辑,全局只读
|
||||
getters: {
|
||||
|
||||
//判断是否登录主页
|
||||
isLoginAccount: (state) => !!state.sid,
|
||||
// 判断是否登录
|
||||
isLogin: (state) => !!state.token,
|
||||
|
||||
// 获取用户ID
|
||||
userId: (state) => state.userInfo?.id ?? 0,
|
||||
//token
|
||||
getToken:(state)=>state.token??"",
|
||||
|
||||
// 格式化用户昵称
|
||||
userNickname: (state) => state.userInfo?.nickname || state.userInfo?.username || '未知用户',
|
||||
// 刷新token
|
||||
getRefToken: (state) => state.refToken??"",
|
||||
|
||||
// 获取用户头像
|
||||
userAvatar: (state) => state.userInfo?.avatar || '',
|
||||
|
||||
// 获取用户角色
|
||||
userRole: (state) => state.userInfo?.role || 'user'
|
||||
// 账号
|
||||
getSid: (state) => state.sid?? '',
|
||||
},
|
||||
|
||||
// 3. 唯一状态修改入口:所有状态变更必须走actions
|
||||
actions: {
|
||||
// 设置用户信息与Token
|
||||
setUserInfo(data: IUserInfo, token: string) {
|
||||
this.userInfo = data
|
||||
this.token = token
|
||||
this.isLoading = false
|
||||
setToken( token: string,refToken :string) {
|
||||
this.token = token,
|
||||
this.refToken = refToken
|
||||
},
|
||||
|
||||
// 仅更新Token
|
||||
setToken(token: string) {
|
||||
this.token = token
|
||||
setSid(sid: string) {
|
||||
this.sid = sid
|
||||
},
|
||||
|
||||
// 退出登录:清空用户状态
|
||||
clearUserInfo() {
|
||||
this.userInfo = null
|
||||
this.token = ''
|
||||
this.isLoading = false
|
||||
},
|
||||
|
||||
// 设置登录加载态
|
||||
setLoginLoading(loading: boolean) {
|
||||
this.isLoading = loading
|
||||
},
|
||||
|
||||
// 更新用户信息(部分更新)
|
||||
updateUserInfo(partialData: Partial<IUserInfo>) {
|
||||
if (this.userInfo) {
|
||||
this.userInfo = { ...this.userInfo, ...partialData }
|
||||
}
|
||||
this.token = '',
|
||||
this.refToken='',
|
||||
this.sid=''
|
||||
}
|
||||
},
|
||||
|
||||
// 4. 持久化配置:仅缓存核心状态(token + userInfo)
|
||||
persist: {
|
||||
storage: piniaPluginPersistedstate.localStorage(),
|
||||
pick: ['token', 'userInfo']
|
||||
pick: ['token','refToken', 'sid']
|
||||
}
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user