自学内容网 自学内容网

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)!