【已解决】React Antd Form.List 表单校验无飘红提示的问题

背景

我想对 Form.List 构建的表单进行校验,比如下拉框中的内容应当至少有一个 XX,表单的长度不能少于多少等等对 List 内容进行校验,并给出飘红提示

问题

比如我有这样一段代码来实现对 list 具体内容的校验,但是写完后发现没有提示,打 console.log 发现也能进入到 throw new Error 里面去,但是就是没有飘红提示

javascript 复制代码
<Form.List name="deployEnvList" rules={[
                {
                  validator: async (_, deployEnvList) => {
                    if (!deployEnvList || deployEnvList.length === 0) {
                      throw new Error('xxx')
                    } else {
                      const configFlag = {
                        env: 0,
                        end: 0,
                      }
                      for (const item of deployEnvList) {
                        if (item?.isDefault === 'true') {
                          configFlag.env++
                        }
                        if (item?.isDeployEnding === 'true') {
                          configFlag.end++
                        }
                      }
                      if (!configFlag.env || !configFlag.end) {
                        throw new Error('请至少配置一个xxx和一个xxx')
                      }
                    }
                  },
                },
              ]}>

解决

看官网,对 Form.list 整体进行校验需要加上 ErrorList 才能正常显示 飘红提示

javascript 复制代码
                    <Form.Item
                      wrapperCol={{ span: 14, offset: 3 }}
                    >
                      <Form.ErrorList errors={errors} />
                    </Form.Item>
相关推荐
黑云压城After3 小时前
H5使用环信实现视频或语音通话
前端·javascript·vue.js
未来之窗软件服务4 小时前
自己写算法(九)网页数字动画函数——东方仙盟化神期
前端·javascript·算法·仙盟创梦ide·东方仙盟·东方仙盟算法
你的人类朋友5 小时前
什么是断言?
前端·后端·安全
FIN66686 小时前
昂瑞微:实现精准突破,攻坚射频“卡脖子”难题
前端·人工智能·安全·前端框架·信息与通信
椎4956 小时前
苍穹外卖前端nginx错误之一解决
运维·前端·nginx
@。1246 小时前
对于灰度发布(金丝雀发布)的了解
开发语言·前端
我有一棵树6 小时前
前端图片加载失败、 img 出现裂图的原因全解析
前端
FIN66686 小时前
昂瑞微冲刺科创板:硬科技与资本市场的双向奔赴
前端·人工智能·科技·前端框架·智能
im_AMBER6 小时前
杂记 14
前端·笔记·学习·web
牧杉-惊蛰6 小时前
disable-devtool 网络安全 禁止打开控制台
前端·css·vue.js