Ant-design中表单多级对象做嵌套表单校验

本文介绍了如何在Vue应用中使用AntDesignVue的useFormhook,动态绑定FormItem组件,并通过validateInfos传递自定义的formData和rules进行输入验证的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在 useForm中拿到一个validateInfos,并传入formData和rules,在FormItem中绑定name名

完整代码如下

<template>
    <Form class="enter-x pt-4" :model="formData" ref="formRef">
        <Row>
            <Col class="mb-3" :span="24">
              <FormItem class="w-24 inline-block align-middle mb-0 mr-3" v-bind="validateInfos['sysOperElectric.green_min_rate']">
                <InputNumber
                  v-model:value="formData.sysOperElectric.green_min_rate"
                  :placeholder="t('routes.operConfig.min')"
                />
              </FormItem>
              <span class="mx-2 text-sm text-slate-400">~</span>
              <FormItem class="w-24 inline-block align-middle mb-0 mr-3" v-bind="validateInfos['sysOperElectric.green_max_rate']">
                <InputNumber
                  v-model:value="formData.sysOperElectric.green_max_rate"
                  :placeholder="t('routes.operConfig.max')"
                />
              </FormItem>
            </Col>
           </Row>
    </Form>
</template>
<script setup lang="ts">
  import { Card, Form, InputNumber, Button, Row, Col, Switch } from 'ant-design-vue';
  import { ref, reactive } from 'vue';
  import { cloneDeep } from 'lodash-es';
  import { integerRule } from '@/utils/validate';

  const FormItem = Form.Item;
  let formData = reactive({
    sysOperElectric: {
      greenMaxRate: undefined,
      greenMinRate: undefined,
      orangeMaxRate: undefined,
      orangeMinRate: undefined,
      redMaxRate: undefined,
      redMinRate: undefined,
    }
  })

  const useForm = Form.useForm;
  const { validateInfos, validate } = useForm(
    formData,
    reactive({
      'sysOperElectric.greenMaxRate': integerRule(),
      'sysOperElectric.greenMinRate': integerRule(),
    })
  )
  function handleSubmit() {
    validate().then((res) => {
        // submit
    })
  }










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值