Vue加ElementUi中的自定义表单校验以及Dialog取消后重置校验
<template>
<el-form ref="form" :model="form" :rules="rules">
<el-form-item label="用户名" prop="username">
<el-input v-model="form.username"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input type="password" v-model="form.password"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button @click="resetForm">重置</el-button>
</el-form-item>
</el-form>
<el-dialog :visible.sync="dialogVisible" @close="handleDialogClose">
<span>这是一段信息</span>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false">取 消</el-button>
<el-button type="primary" @click="dialogVisible = false">确 定</el-button>
</span>
</el-dialog>
</template>
<script>
export default {
data() {
return {
form: {
username: '',
password: ''
},
rules: {
username: [
{ required: true, message: '请输入用户名', trigger: 'blur' },
{ min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入密码', trigger: 'blur' },
{ min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' }
]
},
dialogVisible: false
};
},
methods: {
submitForm() {
this.$refs.form.validate(valid => {
if (valid) {
alert('提交成功!');
} else {
console.log('验证失败');
return false;
}
});
},
resetForm() {
this.$refs.form.resetFields();
},
handleDialogClose() {
this.resetForm();
}
}
};
</script>
这段代码展示了如何在Vue中使用Element UI的表单验证功能,并在对话框关闭时重置表单验证。el-form
组件使用了:model
来绑定表单数据,使用:rules
来绑定表单验证规则,并通过ref
属性来引用表单实例。el-form-item
组件使用prop
属性指定要验证的字段。el-button
触发表单提交或重置,el-dialog
组件使用:visible.sync
来控制对话框的显示与隐藏,并定义了一个close
事件处理函数来在对话框关闭时重置表单。
评论已关闭