deming/pageE/mine/EditUserInfo.vue

178 lines
3.9 KiB
Vue
Raw Normal View History

2020-06-08 07:23:23 +00:00
<template>
<view class="edit-info">
<view class="user-info">
<view class="info-avatar">
<image src="../static/mine/23.png"></image>
</view>
<view class="info-item">
<view class="title">昵称</view>
2020-06-29 00:47:37 +00:00
<view class="value">
<input type="text" v-model="nickname" />
</view>
2020-06-08 07:23:23 +00:00
</view>
<view class="info-item">
<view class="title">性别</view>
2020-06-30 10:06:50 +00:00
<view class="value" @click="selectGender=true">{{ gender == '1' ? '' : '' }}</view>
2020-06-08 07:23:23 +00:00
</view>
2020-06-29 00:47:37 +00:00
<u-select v-model="selectGender" mode="single-column" :list="list" @confirm="setGender"></u-select>
2020-06-08 07:23:23 +00:00
<view class="info-item">
<view class="title">生日</view>
2020-06-29 00:47:37 +00:00
<view class="value" @click="selectBirthday=true">{{ birthday }}</view>
2020-06-08 07:23:23 +00:00
</view>
2020-06-29 00:47:37 +00:00
<u-picker mode="time" v-model="selectBirthday" :params="params" @confirm="setBirthday"></u-picker>
2020-06-08 07:23:23 +00:00
<view class="info-item phone" @click="updatePhone">
<view class="title">手机号</view>
2020-06-29 00:47:37 +00:00
<view class="value">{{ phoneNumber }}</view>
2020-06-08 07:23:23 +00:00
<image src="../static/mine/21.png"></image>
</view>
</view>
<view class="edit-tips">注意修改手机号需要原手机号获取验证码无原手机验证码请联系后台</view>
2020-06-29 00:47:37 +00:00
<view class="edit-btn" @click="updateMemberInfo">完成</view>
2020-06-08 07:23:23 +00:00
</view>
</template>
<script>
2020-07-01 09:32:36 +00:00
import common from '@/static/js/common.js'
2020-06-08 07:23:23 +00:00
export default {
data() {
2020-06-29 00:47:37 +00:00
return {
selectGender: false,
selectBirthday: false,
list: [
{
value: 1,
label: '男'
},
{
value: 2,
label: '女'
}
],
params: {
year: true,
month: true,
day: true,
hour: false,
minute: false,
second: false
},
nickname: '胖胖',
2020-06-30 10:06:50 +00:00
gender: '', // 1男 2女
2020-06-29 00:47:37 +00:00
birthday: '',
phoneNumber: '',
2020-06-30 10:06:50 +00:00
avatar: '',
2020-06-29 00:47:37 +00:00
}
},
onLoad() {
this.getUserInfo();
2020-06-08 07:23:23 +00:00
},
methods: {
2020-06-29 00:47:37 +00:00
getUserInfo() {
this.$u.api.getMemberInfo().then(res => {
if (res.errCode == 0) {
let userInfo = res.data.MemberArray;
[this.nickname, this.phoneNumber, this.birthday, this.gender, this.avatar] = [
userInfo.member_nickname,
userInfo.member_mobile,
2020-07-01 09:32:36 +00:00
common.timestampToDate({timestamp: userInfo.member_birthday}),
2020-06-29 00:47:37 +00:00
userInfo.member_sex,
userInfo.member_avatar,
];
}
})
},
2020-06-30 10:06:50 +00:00
updateMemberInfo() {
2020-06-29 00:47:37 +00:00
this.$u.api.updateMemberInfo({
nickname: this.nickname,
2020-06-30 10:06:50 +00:00
gender: this.gender,
avatar: this.avatar,
2020-06-29 00:47:37 +00:00
birthday: this.birthday,
}).then(res => {
if (res.errCode == 0) {
2020-06-30 10:06:50 +00:00
this.getUserInfo();
2020-06-29 00:47:37 +00:00
}
})
},
setGender(value) {
2020-06-30 10:06:50 +00:00
// console.log(value);
this.gender = value[0].value;
2020-06-29 00:47:37 +00:00
},
setBirthday(value) {
// console.log(value);
2020-07-01 09:32:36 +00:00
this.birthday = value.year + '-' + value.month + '-' + value.day;
2020-06-29 00:47:37 +00:00
},
2020-06-08 07:23:23 +00:00
updatePhone() {
uni.navigateTo({
url: '/pageE/mine/UpdatePhone'
});
}
},
};
</script>
<style lang="scss" scoped>
.edit-info {
min-height: calc(100vh - var(--window-top));
background-color: #ECECEC;
padding-top: 1rpx;
.user-info {
.info-avatar {
text-align: center;
height: 160rpx;
background: rgba(255,255,255,1);
> image {
flex-shrink: 0;
width: 120rpx;
height: 120rpx;
border-radius: 50%;
margin-top: 20rpx;
}
}
.info-item {
display: flex;
align-items: center;
padding: 35rpx 30rpx;
border-top: 2rpx solid #ECECEC;
font-size: 30rpx;
height: 98rpx;
background: rgba(255,255,255,1);
.title {
width: 240rpx;
color: rgba(51,51,51,1);
}
.value {
2020-06-29 00:47:37 +00:00
flex: 1;
height: 98rpx;
line-height: 98rpx;
2020-06-08 07:23:23 +00:00
color: rgba(102,102,102,1);
2020-06-29 00:47:37 +00:00
> input {
height: 98rpx;
}
2020-06-08 07:23:23 +00:00
}
}
.phone {
> image {
margin-left: auto;
width: 11rpx;
height: 22rpx;
}
}
}
.edit-tips {
font-size: 24rpx;
color: rgba(102,102,102,1);
line-height: 40rpx;
margin: 20rpx 0 120rpx;
padding: 0 30rpx;
}
.edit-btn {
margin: 0 auto;
width: 690rpx;
height: 98rpx;
background: rgba(255,120,15,1);
border-radius: 49rpx;
font-size: 36rpx;
color: rgba(255,255,255,1);
line-height: 98rpx;
text-align: center;
}
}
</style>