ant design form动态增减表单项Form.List如何进行动态校验规则

        项目需求:

        在使用ant design form动态增减表单项Form.List时,Form.List中有多组表单项,一组中的最后一个表单项的校验规则是动态的,该组为最后一组时,最后一个表单项是非必填项,其他时候为必填项。假设动态增加了两组表单项,均为填写内容,在必填项校验被触发后,删除了第二组表单项,此时仅剩一组表单项,想要最后一个表单项的校验状态不再显示必填项提示。如下图所示:

想要的效果,最后一个表单项不显示必填项提示:       

        解决思路:

        使用动态校验规则,获取到最后一组的索引,使用form.validateFields重新触发校验规则。

        代码如下:

import React, { useState } from 'react';
import { Form } from 'antd';

const App = () => {

  const [lastIndex, setLastIndex] = useState(false); // form表单最后一组数据的索引

  const [form] = Form.useForm();

  useEffect(() => {
    // 减少表单项时,重新触发表单验证,使form最后一组中最后一个表单项的验证状态不再显示必填项提示
    form.validateFields([['configs', lastIndex, 'lastFormOption']]);
  }, [lastIndex, form]);

  return (
    <Form form={form} initialValues={{ configs: [{}] }} >
      ……
      <Form.List name="configs">
        {(fields, { add, remove }) => (
          <>
            {fields.map(({ key, name, ...restField }, index) => {
              // 这里获取最后一组表单项索引
              setLastIndex(fields.length - 1);
              return (
                <Row
                  key={key}
                >
                  ……
                  <Col span={5}>
                    <Form.Item
                      {...restField}
                      name={[name, 'lastFormOption']}
                      rules={[
                        {
                          required: (fields.length - 1) == index ? false : true,
                          message: '请选择……',
                        },
                      ]}
                    >
                      <Select
                        options={options}
                        disabled={(fields.length - 1) == index}
                        placeholder="最后一条自定义条件为非必填项"
                      />
                    </Form.Item>
                  </Col>
                  <Col span={2}>
                    <MinusCircleOutlined onClick={() => remove(name)} />
                  </Col>
                </Row>
              )
            })}
            <Form.Item >
              <Button type="dashed" onClick={() => add()} block icon={<PlusOutlined />}>
                新增
              </Button>
            </Form.Item>
          </>
        )}
      </Form.List>
    </Form>
  );
};
export default App;

        上述解决方式中,如果App作为一个子组件用到了ForwardRef,会出现下面的告警:

        Warning: Cannot update a component (`ForwardRef(AddRemoveFormItems)`) while rendering a different component (`Field`). To locate the bad setState() call inside `Field`, follow the stack trace as described……

        解决方案:去掉setLastIndex(fields.length - 1);等相关代码,将规则校验放在删除表单组的操作中。代码如下:

<MinusCircleOutlined style={{ fontSize: 24 }} onClick={() => {
  remove(name);
  form.validateFields();
}} />

相关推荐

  1. 动态单的实现和校验

    2024-07-14 00:52:02       25 阅读
  2. 【前端面试】动态单篇

    2024-07-14 00:52:02       22 阅读
  3. elementUI 动态校验单数据的方法

    2024-07-14 00:52:02       44 阅读
  4. vue单rules校验动态

    2024-07-14 00:52:02       34 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-14 00:52:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-14 00:52:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-14 00:52:02       58 阅读
  4. Python语言-面向对象

    2024-07-14 00:52:02       69 阅读

热门阅读

  1. 【DDD】领域驱动设计概念深入探索

    2024-07-14 00:52:02       23 阅读
  2. MATLAB——运算符

    2024-07-14 00:52:02       20 阅读
  3. 2024.7.31 Spyglass lint tcl 使用总结

    2024-07-14 00:52:02       22 阅读
  4. Python解包语法

    2024-07-14 00:52:02       21 阅读
  5. Linux概述

    2024-07-14 00:52:02       21 阅读
  6. ArcGIS Pro SDK (九)几何 2 坐标

    2024-07-14 00:52:02       21 阅读
  7. ls命令学习记录2

    2024-07-14 00:52:02       22 阅读
  8. 无人机在应急救援中的几种应急方案

    2024-07-14 00:52:02       19 阅读