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>

数据结构:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-嘻嘻哈哈~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值