0d1a4181
刘淇
个人中心
|
1
2
3
4
5
6
7
8
9
10
|
<template>
<view class="user-center-page">
<!-- 顶部用户信息栏 -->
<view class="user-info-header">
<!-- 渐变背景层 -->
<view class="header-bg"></view>
<!-- 用户信息主体 -->
<view class="user-info-wrap">
<!-- 头像 -->
<up-avatar
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
11
|
:src="userStore.isLogin ? userInfo.avatar : '/static/imgs/default-avatar.png'"
|
0d1a4181
刘淇
个人中心
|
12
13
14
15
16
|
size="100rpx"
shape="circle"
class="user-avatar"
></up-avatar>
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
17
|
<!-- 用户名+手机号 -->
|
0d1a4181
刘淇
个人中心
|
18
|
<view class="user-info-content">
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
19
20
|
<view class="user-name">{{ userStore.isLogin ? userInfo.username : '未登录' }}</view>
<view class="user-phone">{{ userStore.isLogin ? userInfo.nickname : '--------' }}</view>
|
0d1a4181
刘淇
个人中心
|
21
22
|
</view>
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
23
|
<!-- 登录入口 -->
|
0d1a4181
刘淇
个人中心
|
24
25
26
27
28
29
30
31
32
33
34
|
<up-button
v-if="!userStore.isLogin"
type="primary"
size="mini"
@click="handleLogin"
>
立即登录
</up-button>
</view>
</view>
|
0d1a4181
刘淇
个人中心
|
35
|
<!-- 退出登录按钮 (仅登录状态显示) -->
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
36
|
<view v-if="userStore.isLogin" class="logout-btn-wrap">
|
0d1a4181
刘淇
个人中心
|
37
38
39
40
41
42
43
44
|
<up-button
type="primary"
size="large"
@click="confirmLogout"
>
退出登录
</up-button>
</view>
|
0d1a4181
刘淇
个人中心
|
45
46
47
|
</view>
</template>
|
c293da23
刘淇
新园林init
|
48
|
<script setup lang="ts">
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
49
50
51
|
import { computed } from 'vue'
import { useUserStore } from '@/pinia/user'
import { showModal, onShow } from '@dcloudio/uni-app'
|
0d1a4181
刘淇
个人中心
|
52
53
|
// 初始化Pinia仓库
const userStore = useUserStore()
|
0d1a4181
刘淇
个人中心
|
54
|
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
55
56
|
// 计算属性获取用户信息(响应式)
const userInfo = computed(() => userStore.userInfo.user || {})
|
0d1a4181
刘淇
个人中心
|
57
|
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
58
59
60
|
/**
* 处理登录跳转
*/
|
0d1a4181
刘淇
个人中心
|
61
|
const handleLogin = () => {
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
62
63
|
uni.navigateTo({
url: '/pages/login/index'
|
0d1a4181
刘淇
个人中心
|
64
65
66
|
})
}
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
67
68
69
|
/**
* 确认退出登录(带二次确认)
*/
|
0d1a4181
刘淇
个人中心
|
70
|
const confirmLogout = async () => {
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
71
|
console.log('13213')
|
0d1a4181
刘淇
个人中心
|
72
|
try {
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
73
74
75
76
77
78
79
|
console.log('434')
const res = await uni.showModal({
title: '提示',
content: '确定要退出登录吗?',
confirmText: '退出',
cancelText: '取消'
})
|
0d1a4181
刘淇
个人中心
|
80
|
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
81
82
|
if (res.confirm) {
await userStore.logout()
|
54955fb5
刘淇
巡查和养护 。 失效状态的判断
|
83
|
// uni.showToast({ title: '退出登录成功', type: 'success' })
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
84
|
}
|
0d1a4181
刘淇
个人中心
|
85
86
|
} catch (error) {
console.error('退出登录失败:', error)
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
87
|
uni.showToast({ title: '退出登录失败,请重试', type: 'error' })
|
0d1a4181
刘淇
个人中心
|
88
89
|
}
}
|
c293da23
刘淇
新园林init
|
90
|
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
91
92
93
94
|
// 页面显示时检查登录状态
onShow(() => {
userStore.checkLogin()
})
|
c293da23
刘淇
新园林init
|
95
96
|
</script>
|
0d1a4181
刘淇
个人中心
|
97
98
|
<script lang="ts">
export default {
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
99
100
101
102
|
name: 'UserCenter',
options: {
navigationBarTitleText: '个人中心'
}
|
0d1a4181
刘淇
个人中心
|
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
}
</script>
<style lang="scss" scoped>
.user-center-page {
min-height: 100vh;
background-color: #f5f7fa;
}
// 顶部用户信息栏
.user-info-header {
position: relative;
padding-bottom: 40rpx;
.header-bg {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 320rpx;
background: linear-gradient(135deg, #409eff, #67c23a);
border-radius: 0 0 20rpx 20rpx;
z-index: 1;
}
.user-info-wrap {
position: relative;
z-index: 2;
display: flex;
align-items: center;
padding: 60rpx 30rpx 0;
.user-avatar {
border: 4rpx solid #ffffff;
box-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.1);
|
67af4c8e
刘淇
工作台 如果没有子节点就不渲染父节点
|
138
139
140
141
|
transition: transform 0.2s ease;
&:active {
transform: scale(0.95);
}
|
0d1a4181
刘淇
个人中心
|
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
}
.user-info-content {
margin-left: 30rpx;
flex: 1;
.user-name {
font-size: 32rpx;
font-weight: 600;
color: #ffffff;
margin-bottom: 10rpx;
text-shadow: 0 1rpx 3rpx rgba(0, 0, 0, 0.1);
}
.user-phone {
font-size: 26rpx;
color: rgba(255, 255, 255, 0.9);
|
0d1a4181
刘淇
个人中心
|
159
160
161
162
163
|
}
}
}
}
|
0d1a4181
刘淇
个人中心
|
164
165
166
|
// 退出登录按钮
.logout-btn-wrap {
margin: 200rpx 20rpx 20rpx;
|
0d1a4181
刘淇
个人中心
|
167
|
}
|
c293da23
刘淇
新园林init
|
168
|
</style>
|