139 lines
2.6 KiB
Vue
Raw Normal View History

2024-09-14 17:14:33 +08:00
<template>
2024-09-20 16:28:34 +08:00
<view class="container">
<view class="example">
<uni-forms ref="form" :model="user" labelWidth="80px">
<uni-forms-item label="用户昵称" name="nickName">
<uni-easyinput v-model="user.nickName" placeholder="请输入昵称" />
</uni-forms-item>
<uni-forms-item label="手机号码" name="phonenumber">
<uni-easyinput v-model="user.phonenumber" placeholder="请输入手机号码" />
</uni-forms-item>
<uni-forms-item label="邮箱" name="email">
<uni-easyinput v-model="user.email" placeholder="请输入邮箱" />
</uni-forms-item>
<uni-forms-item label="性别" name="sex" required>
<uni-data-checkbox v-model="user.sex" :localdata="sexs" />
</uni-forms-item>
</uni-forms>
<button type="primary" @click="submit">提交</button>
</view>
</view>
2024-09-14 17:14:33 +08:00
</template>
<script>
2024-09-20 16:28:34 +08:00
import { getUserProfile } from '@/api/system/user';
import { updateUserProfile } from '@/api/system/user';
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
export default {
data() {
return {
user: {
nickName: '',
phonenumber: '',
email: '',
sex: ''
},
sexs: [
{
text: '男',
value: 0
},
{
text: '女',
value: 1
}
],
rules: {
nickName: {
rules: [
{
required: true,
errorMessage: '用户昵称不能为空'
}
]
},
phonenumber: {
rules: [
{
required: true,
errorMessage: '手机号码不能为空'
},
{
pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/,
errorMessage: '请输入正确的手机号码'
}
]
},
email: {
rules: [
{
required: true,
errorMessage: '邮箱地址不能为空'
},
{
format: 'email',
errorMessage: '请输入正确的邮箱地址'
}
]
}
}
};
},
onLoad() {
this.getUser();
},
onReady() {
this.$refs.form.setRules(this.rules);
},
methods: {
getUser() {
getUserProfile().then((response) => {
this.user = response.data.user;
});
},
submit(ref) {
this.$refs.form.validate().then((res) => {
updateUserProfile(this.user).then((response) => {
this.$modal.msgSuccess('修改成功');
});
});
}
}
};
2024-09-14 17:14:33 +08:00
</script>
<style lang="scss">
2024-09-20 16:28:34 +08:00
page {
background-color: #ffffff;
}
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
.example {
padding: 15px;
background-color: #fff;
}
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
.segmented-control {
margin-bottom: 15px;
}
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
.button-group {
margin-top: 15px;
display: flex;
justify-content: space-around;
}
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
.form-item {
display: flex;
align-items: center;
flex: 1;
}
2024-09-14 17:14:33 +08:00
2024-09-20 16:28:34 +08:00
.button {
display: flex;
align-items: center;
height: 35px;
line-height: 35px;
margin-left: 10px;
}
2024-09-14 17:14:33 +08:00
</style>