【已解决】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>
相关推荐
南屿im3 分钟前
基于 Promise 封装 Ajax 请求:从 XMLHttpRequest 到现代化异步处理
前端·javascript
青松学前端3 分钟前
vue-2.7源码解读之初始化流程和响应式实现
前端·vue.js·前端框架
杨进军3 分钟前
前端线上问题的那些事儿
前端·javascript·前端框架
每天开心5 分钟前
深入探索 React Hooks: useState 与 useEffect 的力量 🌟
前端·javascript·ai编程
流星稍逝8 分钟前
Vue3 + Uniapp 图片压缩公共方法封装
前端·vue.js
受之以蒙8 分钟前
Rust & WASM 之 wasm-bindgen 基础:让 Rust 与 JavaScript 无缝对话
前端·笔记·rust
中微子9 分钟前
React Props 传值规范详解
前端·react.js
namehu9 分钟前
Taro 小程序 Video 组件 referrer-policy="origin" 属性失效排查记
前端·taro
卸任14 分钟前
性能优化大作战:React.memo 在可编辑列表中的奇效
前端·javascript·react.js
WildBlue22 分钟前
阮一峰闭包:JavaScript最优雅的"背包"魔法!✨
前端·javascript