vue封装el-from表单,实现一个demo
时间: 2024-03-06 21:47:45 浏览: 70
好的,这里是一个简单的示例:
```vue
<template>
<el-form :model="formData" :rules="formRules" ref="form" label-width="100px">
<el-form-item label="用户名" prop="username">
<el-input v-model="formData.username"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input type="password" v-model="formData.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>
</template>
<script>
export default {
data() {
return {
formData: {
username: '',
password: ''
},
formRules: {
username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
password: [{ required: true, message: '请输入密码', trigger: 'blur' }]
}
}
},
methods: {
submitForm() {
this.$refs.form.validate(valid => {
if (valid) {
// 表单验证通过,提交表单数据
console.log(this.formData)
} else {
// 表单验证失败
console.log('表单验证失败')
return false
}
})
},
resetForm() {
this.$refs.form.resetFields()
}
}
}
</script>
```
这个示例中使用了 `el-form` 和 `el-form-item` 组件来构建表单,使用 `v-model` 指令绑定表单数据,使用 `:rules` 属性来设置表单验证规则,使用 `$refs.form` 引用表单组件并调用其 `validate` 和 `resetFields` 方法实现表单验证和重置功能。
阅读全文