用户修改

This commit is contained in:
@fawn-nine
2023-10-19 18:04:56 +08:00
parent efcf6d45db
commit 9c662d1d9d
11 changed files with 630 additions and 229 deletions

View File

@@ -5,11 +5,19 @@
<el-form-item label="姓名" prop="name">
<el-input v-model="dataForm.name" placeholder="姓名"></el-input>
</el-form-item>
<el-form-item label="电话" prop="tel">
<el-input v-model="dataForm.tel" placeholder="电话"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password" v-if="!dataForm.id">
<el-input v-model="dataForm.password" placeholder="密码"></el-input>
</el-form-item>
<div v-if="dataForm.id">
<el-form-item label="年龄" prop="age">
<el-input v-model="dataForm.age" placeholder="年龄"></el-input>
</el-form-item>
<el-form-item label="性别" prop="sex">
<!-- <el-input v-model="dataForm.sex" placeholder="性别"></el-input> -->
<el-radio v-model="dataForm.sex" :label=2>保密</el-radio>
<el-radio v-model="dataForm.sex" :label=1></el-radio>
<el-radio v-model="dataForm.sex" :label=0></el-radio>
</el-form-item>
@@ -26,17 +34,14 @@
</el-form-item>
<el-form-item label="昵称" prop="nickname">
<el-input v-model="dataForm.nickname" placeholder="昵称"></el-input>
</el-form-item>
<el-form-item label="电话" prop="tel">
<el-input v-model="dataForm.tel" placeholder="电话"></el-input>
</el-form-item>
</el-form-item>
<!-- <el-form-item label="密码" prop="password">
<el-input v-model="dataForm.password" placeholder="密码"></el-input>
</el-form-item> -->
<el-form-item label="会员类型" prop="vip">
<!-- <el-form-item label="会员类型" prop="vip">
<el-input v-model="dataForm.vip" placeholder="0-普通 1-vip"></el-input>
</el-form-item>
<el-form-item label="vip 有效期" prop="vipValidtime">
</el-form-item> -->
<!-- <el-form-item label="vip 有效期" prop="vipValidtime">
<el-date-picker
v-model="dataForm.vipValidtime"
type="datetime"
@@ -44,8 +49,8 @@
align="right"
:picker-options="pickerOptions">
</el-date-picker>
<!-- <el-input v-model="dataForm.vipValidtime" placeholder="vip 有效期"></el-input> -->
</el-form-item>
<el-input v-model="dataForm.vipValidtime" placeholder="vip 有效期"></el-input>
</el-form-item> -->
<el-form-item label="花生币" prop="peanutCoin">
<!-- <el-input v-model="dataForm.peanutCoin" placeholder="花生币"></el-input> -->
<el-input-number disabled v-model="dataForm.peanutCoin" label="花生币"></el-input-number>
@@ -65,6 +70,7 @@
<el-form-item label="删除标记" prop="delFlag">
<el-input v-model="dataForm.delFlag" placeholder="删除标记"></el-input>
</el-form-item> -->
</div>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="handlereset">取消</el-button>
@@ -82,11 +88,33 @@ export default {
visible: false,
dialogVisible: false,
fileList: [],
pickerOptions:{
shortcuts: [{
text: '今天',
onClick(picker) {
picker.$emit('pick', new Date());
}
}, {
text: '昨天',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24);
picker.$emit('pick', date);
}
}, {
text: '一周前',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', date);
}
}]
},
dataForm: {
id: 0,
name: '',
name: '',
age: '',
sex: '',
sex: 2,
avatar: '',
nickname: '',
tel: '',
@@ -101,9 +129,12 @@ export default {
delFlag: '',
},
dataRule: {
// name: [
// { required: true, message: '姓名不能为空', trigger: 'blur' }
// ],
name: [
{ required: true, message: '姓名不能为空', trigger: 'blur' }
],
password: [
{ required: true, message: '密码不能为空', trigger: 'blur' }
],
// age: [
// { required: true, message: '年龄不能为空', trigger: 'blur' }
// ],
@@ -116,9 +147,19 @@ export default {
// nickname: [
// { required: true, message: '昵称不能为空', trigger: 'blur' }
// ],
// tel: [
// { required: true, message: '电话不能为空', trigger: 'blur' }
// ],
tel: [
{ required: true, message: '电话不能为空', trigger: 'blur' },
{
validator: function(rule, value, callback) {
if (/^1[34578]\d{9}$/.test(value) == false) {
callback(new Error("手机号格式错误"));
} else {
callback();
}
},
trigger: "blur"
}
],
// password: [
// { required: true, message: '密码不能为空', trigger: 'blur' }
// ],
@@ -164,7 +205,7 @@ export default {
if (data && data.code === 0) {
this.dataForm.name = data.user.name
this.dataForm.age = data.user.age
this.dataForm.sex = data.user.sex
this.dataForm.sex = data.user.sex
this.dataForm.avatar = data.user.avatar
this.dataForm.nickname = data.user.nickname
this.dataForm.tel = data.user.tel
@@ -177,7 +218,7 @@ export default {
this.dataForm.createTime = data.user.createTime
this.dataForm.updateTime = data.user.updateTime
this.dataForm.delFlag = data.user.delFlag
if (data.user.avatar != "") {
if (data.user.avatar && data.user.avatar != "") {
var img = { name: '', url: data.user.avatar }
var attr = []
attr.push(img)
@@ -191,28 +232,38 @@ export default {
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.$http({
url: this.$http.adornUrl(`/book/user/${!this.dataForm.id ? 'save' : 'update'}`),
method: 'post',
data: this.$http.adornData({
'id': this.dataForm.id || undefined,
let myData = {}
if(!this.dataForm.id){
myData = {
'name': this.dataForm.name,
'tel': this.dataForm.tel,
}
}else{
myData = {
'id': this.dataForm.id,
'name': this.dataForm.name,
'age': this.dataForm.age,
'sex': this.dataForm.sex,
'avatar': this.dataForm.avatar,
'nickname': this.dataForm.nickname,
'tel': this.dataForm.tel,
'password': this.dataForm.password,
'vip': this.dataForm.vip,
'vipValidtime': this.dataForm.vipValidtime,
'peanutCoin': this.dataForm.peanutCoin,
'readTime': this.dataForm.readTime,
'lastLoginTime': this.dataForm.lastLoginTime,
'createTime': this.dataForm.createTime,
'updateTime': this.dataForm.updateTime,
'delFlag': this.dataForm.delFlag
})
// 'password': this.dataForm.password,
// 'vip': this.dataForm.vip,
// 'vipValidtime': this.dataForm.vipValidtime,
// 'peanutCoin': this.dataForm.peanutCoin,
// 'readTime': this.dataForm.readTime,
// 'lastLoginTime': this.dataForm.lastLoginTime,
// 'createTime': this.dataForm.createTime,
// 'updateTime': this.dataForm.updateTime,
// 'delFlag': this.dataForm.delFlag
}
}
console.log('myData', myData)
if (valid) {
this.$http({
url: this.$http.adornUrl(`/book/user/${!this.dataForm.id ? 'save' : 'update'}`),
method: 'post',
data: this.$http.adornData(myData)
}).then(({ data }) => {
if (data && data.code === 0) {
this.$message({
@@ -230,7 +281,7 @@ export default {
})
}
})
},
},
handlePictureCardPreview(file) {
this.dataForm.avatar = file.url;
this.dialogVisible = true;
@@ -246,7 +297,10 @@ export default {
handleRemove(file) {
this.dataForm.avatar = '';
},
handlereset(){
handlereset(){
// console.log('关闭了')
this.$refs['dataForm'].resetFields()
this.dataForm.password = ''
this.fileList = [],
this.visible = false
},