antd + VUE循环form-item的校验 循环校验(多层循环)
使用a-form 循环校验: v-model 动态渲染的,主要是name 跟v-model 绑定的数据需要是一样的,校验才会生效,:name="['deviceModels', index, 'parentId']" 主要是这个
<!-- 动态渲染设备模型和表单项 -->
<a-row :gutter="24" v-for="(device, index) in jobAddUpdateForm.deviceModels" :key="index">
<!-- 设备模型选择框 -->
<a-col span="6">
<a-form-item :name="['deviceModels', index, 'parentId']" :label="`设备模型${index + 1}`" :rules="[{ required: true, message: `设备模型${index + 1}不能为空` }]">
<div v-if="pageData.operateType == 3">{
{ jobAddUpdateForm.deviceModels[index].name }}</div>
<a-select v-else placeholder="请选择设备模型" v-model:value="device.parentId" allowClear show-search @change="(e) => equipmentChange(e, index)">
<a-select-option v-for="item in deviceManagementData" :key="item.id" :value="item.id">
{
{ item.name }}
</a-select-option>
</a-select>
</a-form-item>
</a-col>
<!-- 动态表单项 -->
<a-col v-for="(item, fieldIndex) in device.fields" :key="fieldIndex" span="6">
<a-form-item :name="['deviceModels', [index], item.value]" :label="item.label" :rules="[{ required: true, message: `${item.label}不能为空` }]">
<div v-if="pageData.operateType == 3">{
{ device[item.value] }}</div>
<a-input v-else :placeholder="`请输入${item.label}`" :maxlength="128" v-model:value="device[item.value]" allowClear @change="onSearch" />
</a-form-item>
</a-col>
</a-row>
数据结构:
原文地址:https://blog.csdn.net/m0_71835253/article/details/145227859
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!