2025-01-02 21:10:40 +08:00
|
|
|
<template>
|
2025-04-03 11:12:42 +08:00
|
|
|
<page-meta :page-font-size="fontValue+'px'" :root-font-size="fontValue+'px'"></page-meta>
|
2025-01-02 21:10:40 +08:00
|
|
|
<view class="container">
|
|
|
|
|
<!-- 顶部导航栏 -->
|
2025-01-10 15:49:19 +08:00
|
|
|
<!-- <view class="header"> -->
|
|
|
|
|
<!-- <view class="back-icon" @click="goBack"> -->
|
|
|
|
|
<!-- <image class="icon" :src="require('@/static/images/my/notice.png')" mode="aspectFit"></image> -->
|
|
|
|
|
<!-- </view> -->
|
|
|
|
|
<!-- <text class="title">个人信息</text> -->
|
|
|
|
|
<!-- </view> -->
|
2025-01-02 21:10:40 +08:00
|
|
|
|
|
|
|
|
<!-- 菜单列表 -->
|
|
|
|
|
<view class="menu-list">
|
|
|
|
|
<view
|
|
|
|
|
v-for="(item, index) in menuItems"
|
|
|
|
|
:key="index"
|
|
|
|
|
class="menu-item"
|
2025-01-10 15:49:19 +08:00
|
|
|
@click="handleMenuItemClick(item.path, item.title)"
|
2025-01-02 21:10:40 +08:00
|
|
|
>
|
|
|
|
|
<text class="menu-text">{{ item.title }}</text>
|
|
|
|
|
<image class="arrow-icon" :src="require('@/static/images/my/enter.png')" mode="aspectFit"></image>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-02-19 09:34:34 +08:00
|
|
|
|
2025-04-03 11:12:42 +08:00
|
|
|
<u-button shape="circle" color="#FF6816" @click="onLoginOut" style="width: 90%;margin: 0 auto;height: 40px;position:absolute;bottom: 50px;left: 5%;font-size: 30rpx;">
|
2025-02-19 09:34:34 +08:00
|
|
|
退出登录
|
|
|
|
|
</u-button>
|
2025-01-10 15:49:19 +08:00
|
|
|
|
|
|
|
|
<!-- uView 弹框组件 -->
|
|
|
|
|
<u-modal
|
|
|
|
|
:show="showDialog"
|
|
|
|
|
:show-cancel-button="true"
|
|
|
|
|
title="提示"
|
|
|
|
|
:content="dialogContent"
|
|
|
|
|
@confirm="handleConfirm"
|
|
|
|
|
@cancel="handleCancel"
|
|
|
|
|
></u-modal>
|
2025-01-02 21:10:40 +08:00
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2025-04-22 13:05:32 +08:00
|
|
|
import Cookies from "js-cookie";
|
|
|
|
|
import UModal from '@/uni_modules/uview-ui/components/u-modal/u-modal.vue'
|
|
|
|
|
|
2025-01-02 21:10:40 +08:00
|
|
|
export default {
|
2025-01-10 15:49:19 +08:00
|
|
|
components: { UModal },
|
2025-01-02 21:10:40 +08:00
|
|
|
data() {
|
|
|
|
|
return {
|
2025-04-22 13:05:32 +08:00
|
|
|
fontValue:Cookies.get('fontSize') || 8,
|
2025-01-02 21:10:40 +08:00
|
|
|
menuItems: [
|
|
|
|
|
{
|
|
|
|
|
title: '基本信息',
|
|
|
|
|
path: '/pages/mine/me/basicInfo'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '我的地址',
|
2025-01-10 15:49:19 +08:00
|
|
|
path: '/pages/mine/me/myAddress'
|
2025-01-02 21:10:40 +08:00
|
|
|
},
|
2025-03-14 15:15:54 +08:00
|
|
|
{
|
|
|
|
|
title: '健康信息',
|
|
|
|
|
path: '/pages/mine/me/healthInformation'
|
|
|
|
|
},
|
2025-01-02 21:10:40 +08:00
|
|
|
{
|
|
|
|
|
title: '人脸上传',
|
2025-01-03 18:28:23 +08:00
|
|
|
path: '/pages/mine/me/faceUpload'
|
2025-01-02 21:10:40 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '修改密码',
|
2025-01-16 11:09:35 +08:00
|
|
|
path: '/pages/mine/me/changePassword'
|
2025-01-02 21:10:40 +08:00
|
|
|
},
|
2025-02-19 09:34:34 +08:00
|
|
|
{
|
|
|
|
|
title: '绑定手机号',
|
|
|
|
|
path: '/pages/mine/me/bindingPhone'
|
|
|
|
|
},
|
2025-01-02 21:10:40 +08:00
|
|
|
{
|
|
|
|
|
title: '挂失解绑',
|
2025-02-19 09:34:34 +08:00
|
|
|
path: '/pages/mine/me/carteenCard'
|
2025-01-02 21:10:40 +08:00
|
|
|
}
|
2025-01-10 15:49:19 +08:00
|
|
|
],
|
|
|
|
|
showDialog: false, // 控制弹框显示隐藏
|
|
|
|
|
dialogContent: '' // 弹框内容
|
2025-01-02 21:10:40 +08:00
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
2025-02-19 09:34:34 +08:00
|
|
|
//返回
|
2025-01-02 21:10:40 +08:00
|
|
|
goBack() {
|
|
|
|
|
uni.navigateBack()
|
2025-02-19 09:34:34 +08:00
|
|
|
},
|
|
|
|
|
//退出
|
|
|
|
|
onLoginOut() {
|
|
|
|
|
this.$modal.confirm('确定注销并退出系统吗?').then(() => {
|
|
|
|
|
this.$store.dispatch('LogOut').then(() => {
|
2025-04-22 13:05:32 +08:00
|
|
|
Cookies.remove('token')
|
2025-03-24 15:46:35 +08:00
|
|
|
uni.reLaunch({ url: '/pages/login' })
|
2025-02-19 09:34:34 +08:00
|
|
|
})
|
|
|
|
|
})
|
2025-01-02 21:10:40 +08:00
|
|
|
},
|
2025-01-10 15:49:19 +08:00
|
|
|
handleMenuItemClick(path, title) {
|
2025-02-19 09:34:34 +08:00
|
|
|
// if (title === '挂失解绑') {
|
|
|
|
|
// console.log('挂失解绑')
|
|
|
|
|
// this.dialogContent = '您确定要执行挂失解绑操作吗?'
|
|
|
|
|
// this.showDialog = true
|
|
|
|
|
// } else {
|
2025-01-10 15:49:19 +08:00
|
|
|
this.navigateTo(path)
|
2025-02-19 09:34:34 +08:00
|
|
|
// }
|
2025-01-10 15:49:19 +08:00
|
|
|
},
|
2025-01-02 21:10:40 +08:00
|
|
|
navigateTo(url) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url
|
|
|
|
|
})
|
2025-01-10 15:49:19 +08:00
|
|
|
},
|
|
|
|
|
handleConfirm() {
|
|
|
|
|
console.log('用户点击了确认')
|
|
|
|
|
// 在这里处理确认逻辑
|
|
|
|
|
this.showDialog = false
|
|
|
|
|
// 例如:执行挂失解绑操作
|
|
|
|
|
this.unbind()
|
|
|
|
|
},
|
|
|
|
|
handleCancel() {
|
|
|
|
|
console.log('用户点击了取消')
|
|
|
|
|
// 在这里处理取消逻辑
|
|
|
|
|
this.showDialog = false
|
|
|
|
|
},
|
|
|
|
|
unbind() {
|
|
|
|
|
// 挂失解绑的具体逻辑
|
|
|
|
|
console.log('执行挂失解绑操作')
|
|
|
|
|
// 例如:调用 API 进行挂失解绑
|
2025-01-02 21:10:40 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
|
.container {
|
2025-01-03 18:28:23 +08:00
|
|
|
margin-top: -20px;
|
|
|
|
|
background-color: #FFFFFF;
|
2025-03-24 15:46:35 +08:00
|
|
|
height: 100vh;
|
2025-02-19 09:34:34 +08:00
|
|
|
position: relative;
|
2025-01-02 21:10:40 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.menu-list {
|
|
|
|
|
background: #FFFFFF;
|
|
|
|
|
|
|
|
|
|
.menu-item {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
padding: 32rpx;
|
2025-01-03 18:28:23 +08:00
|
|
|
border-bottom: 1rpx solid #FFFFFF;
|
2025-01-02 21:10:40 +08:00
|
|
|
|
|
|
|
|
&:last-child {
|
|
|
|
|
border-bottom: none;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.menu-text {
|
|
|
|
|
font-size: 32rpx;
|
|
|
|
|
color: #333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.arrow-icon {
|
|
|
|
|
width: 32rpx;
|
|
|
|
|
height: 32rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|