【已解决】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>
相关推荐
0思必得011 分钟前
[Web自动化] Selenium处理文件上传和下载
前端·爬虫·python·selenium·自动化·web自动化
摘星编程13 分钟前
React Native鸿蒙:Calendar日程标记显示
react native·react.js·harmonyos
phltxy1 小时前
Vue3入门指南:从环境搭建到数据响应式,开启高效前端开发之旅
前端·javascript·vue.js
小飞大王6661 小时前
CSS基础知识
前端·css
Charlie_lll1 小时前
学习Three.js–风车星系
前端·three.js
代码游侠1 小时前
学习笔记——Linux内核与嵌入式开发1
linux·运维·前端·arm开发·单片机·嵌入式硬件·学习
玩电脑的辣条哥2 小时前
幽灵回复AI已回复但前端不显示的排查与修复
前端·人工智能
石去皿2 小时前
轻量级 Web 应用 —— 把一堆图片按指定频率直接拼成视频,零特效、零依赖、零命令行
前端·音视频
星夜落月3 小时前
Web-Check部署全攻略:打造个人网站监控与分析中心
运维·前端·网络
摘星编程3 小时前
OpenHarmony + RN:ProgressBar进度条组件
javascript·react native·react.js