el-form自定义表单项的校验错误信息

博客讲述动态表单根据后端获取类型生成表单项,表单内容传后台校验,若有错误信息需显示在对应表单项下。查找无果后重新查看el - form属性,找到显示错误信息的表单项属性,绑定对象类型data值到error属性,后端获取错误信息直接赋值。

有一个动态表单根据后端获取的类型生成若干表单项,表单的内容传到后台进行校验,如果有错误信息则显示在相应的表单项下。

查了很久无果,大部分是和自定义验证规则有关的,于是又重新看el-form属性,果不其然有一个表单项的属性用来显示错误信息(之前可能眼瞎了)。
在这里插入图片描述
接下来的事就很简单了,绑定一个对象类型的data值到动态表单项的error属性,后端获取到了错误信息直接赋值就好。
示例如下:

<el-form-item :label="item.name" :prop="item.key" :error="errorMessage[item.key]">
</el-form-item>

没事还是得多看看官网。

<el-dialog :title="editingIndex === -1 ? '新增字段' : '编辑字段'" :visible.sync="fieldEditorVisible" width="600px"> <el-form label-width="100px"> <!-- 字段类型选择 --> <el-form-item label="字段类型"> <el-select v-model="tempField.type" @change="handleTypeChange"> <el-option label="输入框" value="el-input"/> <el-option label="下拉框" value="el-select"/> </el-select> </el-form-item> <!-- 基础属性 --> <el-form-item label="字段标签" required> <el-input v-model="tempField.label"/> </el-form-item> <el-form-item label="绑定模型" required> <el-input v-model="tempField.model" :disabled="editingIndex !== -1"> <template slot="append"> {{ tempField.model | camelCase }} </template> </el-input> </el-form-item> <!-- 下拉框选项(仅select类型显示) --> <template v-if="tempField.type === 'el-select'"> <el-divider>选项配置</el-divider> <draggable v-model="tempField.options"> <div v-for="(opt, index) in tempField.options" :key="index"> <el-input v-model="opt.label" placeholder="显示文本" style="width: 200px"/> <el-input v-model="opt.value" placeholder="存储值" style="width: 200px; margin-left: 10px"/> <el-button @click="removeOption(index)" icon="el-icon-delete" circle></el-button> </div> </draggable> <el-button @click="addOption">+ 添加选项</el-button> </template> </el-form> <div slot="footer"> <el-button @click="fieldEditorVisible = false">取消</el-button> <el-button type="primary" @click="saveField">保存</el-button> </div> </el-dialog>在修改字段的label时候会自动地把值同步给value且value不可被用户选中修改详细代码
03-14
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值