今天修改bug 工作上的一些问题和写法记录
起因是因为再点击两个修改密码时候只有一个弹框,我再想怎么去分辨他们
因为修改密码的接口都是同一个根据特定值来判断是哪一个密码修改所以用的同一个弹框
第一次遇到这种写法
<el-dropdown-item>
<div @click="(dialogFormVisible = true), (form.updateType = 1)">
修改密码
</div>
</el-dropdown-item>
<el-dropdown-item>
<div @click="(dialogFormVisible = true), (form.updateType = 2)">
修改支付密码
</div>
直接进行点击传值 让Dialog显示 然后给表单的特定属性进行赋值用来分辨弹框的显示类型
form: {
updateType: 1,//表单类型
oldpassword: '',
password: '',
checkPass: ''
},
然后关于表单验证
在弹框中设置相关验证规则rules
避免工作代码,,我直接贴的element的自定义表单
<el-form :model="ruleForm" status-icon :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
<el-form-item label="密码" prop="pass">
<el-input type="password" v-model="ruleForm.pass" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="确认密码" prop="checkPass">
<el-input type="password" v-model="ruleForm.checkPass" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="年龄" prop="age">
<el-input v-model.number="ruleForm.age"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
<el-button @click="resetForm('ruleForm')">重置</el-button>
</el-form-item>
</el-form>
<script>
export default {
data() {
var checkAge = (rule, value, callback) => {
if (!value) {
return callback(new Error('年龄不能为空'));
}
setTimeout(() => {
if (!Number.isInteger(value)) {
callback(new Error('请输入数字值'));
} else {
if (value < 18) {
callback(new Error('必须年满18岁'));
} else {
callback();
}
}
}, 1000);
};
var validatePass = (rule, value, callback) => {
if (value === '') {
callback(new Error('请输入密码'));
} else {
if (this.ruleForm.checkPass !== '') {
this.$refs.ruleForm.validateField('checkPass');
}
callback();
}
};
var validatePass2 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'));
} else if (value !== this.ruleForm.pass) {
callback(new Error('两次输入密码不一致!'));
} else {
callback();
}
};
return {
ruleForm: {
pass: '',
checkPass: '',
age: ''
},
rules: {
pass: [
{ validator: validatePass, trigger: 'blur' }
],
checkPass: [
{ validator: validatePass2, trigger: 'blur' }
],
age: [
{ validator: checkAge, trigger: 'blur' }
]
}
};
},
methods: {
submitForm(formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
alert('submit!');
} else {
console.log('error submit!!');
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
}
</script>
一般而言这样写rules就可以了 是否必填 提示信息 验证方式
rules: {
oldpassword: [
{ required: true, message: '请输入原密码', trigger: 'blur' },
{ min: 6, max: 12, message: '长度在 6 ~ 12 个字符', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入新密码', trigger: 'blur' },
{ validator: validatePass, trigger: 'blur' }
]
}
是否清空表单输入内容的回调---点击取消和确定按钮
取消按钮 重置表格和验证规则
<el-button @click="resetForm('form表单绑定的ref值')">
取 消
</el-button>
<el-button type="primary" @click="submitForm('form表单绑定的ref值')">
确 定
</el-button>
resetForm(formName) {
this.$refs[formName].resetFields()
this.dialogFormVisible = false
},
resetFields | 对整个表单进行重置,将所有字段值重置为初始值并移除校验结果 |
确定按钮
this.$refs[formName].validate都是固定写法 可以看官方文档
submitForm(formName) {
this.$refs[formName].validate(valid => {
//vaild打印出来是true
if (valid) {
modifyPassword(this.form).then(() => {
this.dialogFormVisible = false //关闭弹框
//重置表单属性
this.form.updateType === 1 && this.loginOut()
})
} else {
console.log('error submit!!')
return false
}
})
},
validate | 对整个表单进行校验的方法,参数为一个回调函数。该回调函数会在校验结束后被调用,并传入两个参数:是否校验成功和未通过校验的字段。若不传入回调函数,则会返回一个 promise | Function(callback: Function(boolean, object)) |