Blame view

pages/mine/index.vue 3.7 KB
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
83
84
      if (res.confirm) {
        await userStore.logout()
        uni.showToast({ title: '退出登录成功', type: 'success' })
      }
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>