在Vue中使用Element UI的el-form
组件时,可以动态添加el-form-item
元素,并为它们添加验证规则。以下是一个简单的例子,展示了如何实现这一功能:
<template>
<el-form :model="form" :rules="rules" ref="dynamicForm">
<el-form-item
v-for="(item, index) in form.items"
:key="index"
:label="'Item ' + (index + 1)"
:prop="'items.' + index + '.value'"
:rules="{ required: true, message: 'This field is required', trigger: 'blur' }"
>
<el-input v-model="item.value"></el-input>
<el-button @click="removeItem(index)">Remove</el-button>
</el-form-item>
<el-button @click="addItem">Add Item</el-button>
<el-button type="primary" @click="submitForm">Submit</el-button>
</el-form>
</template>
<script>
export default {
data() {
return {
form: {
items: [{ value: '' }]
},
rules: {}
};
},
methods: {
addItem() {
this.form.items.push({ value: '' });
this.$nextTick(() => {
this.$refs.dynamicForm.addField();
});
},
removeItem(index) {
this.form.items.splice(index, 1);
},
submitForm() {
this.$refs.dynamicForm.validate((valid) => {
if (valid) {
alert('Form is valid!');
} else {
console.log('Form is invalid');
return false;
}
});
}
}
};
</script>
在这个例子中,我们定义了一个form
对象,它包含一个items
数组。每个el-form-item
都与items
数组中的一个对象相绑定。我们使用v-for
来渲染这些项,并为它们添加了一个移除按钮。
添加新项目时,我们推入一个新的空对象到items
数组,并使用this.$nextTick
确保在DOM更新后调用addField
方法。这是必要的,因为Element UI的表单组件需要在动态添加字段时知道新的表单项。
提交表单时,我们调用this.$refs.dynamicForm.validate
方法来验证所有的表单项。如果验证通过,我们处理表单数据;如果验证失败,我们停止处理。