需求:el-form里面el-form-item的数据基本可以重复,可以遍历生成,el-form-item里面有下拉和input,选择某个下拉出现input,某个下拉隐藏input,如下图:
思路:动态生成el-form-item,并在el-form-item绑定校验规则
<el-form ref="stockForm" :model="stockForm" class="zd-el-form" size="mini" inline label-width="160px" > <div v-for="(item, index) in formItemList" :key="index" class="el-form-item-box" > <el-form-item :label="item.label+':'" :prop="item.status" :rules="rulesItemStatus" > <el-select v-model="stockForm[item.status]" class="item-placeholder" placeholder="请选择" clearable @change="val => setParamStatusListChange(val, index)" // 回调函数可以带多些需要的参数 > <el-option v-for="ite in setParamStatusList" :key="ite.value" :label="ite.name" :value="ite.value" /> </el-select> </el-form-item> <el-form-item v-if="stockForm[item.status] ==='2' || stockForm[item.status] ==='1'" :prop="item.value" :rules="rulesItemValue" > <el-input v-model="stockForm[item.value]" type="text" min="0" maxlength="10" clearable onkeydown.native="return (/[\d]/.test(String.fromCharCode(event.keyCode)))" // 只能输入数字正则校验 /> </el-form-item> <el-tooltip class="item" effect="light" placement="top" > <div slot="content">{{ item.tooltip }}</div> <i style="color: #D9D9D9;padding-top: 18px;" class="el-icon-question" /> </el-tooltip> </div> </el-form>
校验写在data的return里面:
formItemData是每个el-form-item信息的Object数组有label、name、status、value、tooltip
stockForm是绑定的表单
stockForm: { attr1Value: '', attr1Status: '', attr2Value: '', attr2Status: '', attr3Value: '', attr3Status: '', attr4Value: '', attr4Status: '', attr5Value: '', attr5Status: '', attr6Value: '', attr6Status: '', attr7Value: '', attr7Status: '' },
attrStatusArr: {
attr1Status: '',
attr2Status: '',
attr3Status: '',
attr4Status: '',
attr5Status: '',
attr6Status: '',
attr7Status: ''
}