当前位置: 首页 > news >正文

【Antd】antd form表单的rules文案无法跟随状态重渲染的原因及解决办法

问题背景

我有两个表单项,当我选择出库类型,调用onChange改变inOutType 状态,这时候发现这句代码不生效:

rules={[{ required: true, message: `请选择${inOutType === 1 ? '持有人' : '负责人'}` }]}

示例代码

<TypographyForm.Group><TypographyForm.Itemlabel="出库类型"name="inOutType"col={{ span: 24 }}rules={[{ required: true, message: '请选择出库类型' }]}><Select placeholder="出库类型" loading={inApplyLoading} onChange={onInOutTypeChange}>{inApplyType &&inApplyType.data?.[3]?.map((item) => (<Select.Option value={item?.dictKey} key={item?.dictKey}>{item?.dictValue}</Select.Option>))}</Select>
</TypographyForm.Item><TypographyForm.Itemlabel={inOutType === 1 ? '持有人' : '负责人'}name="holderEmployeeCode"col={{ span: 24 }}rules={[{ required: true, message: `请选择${inOutType === 1 ? '持有人' : '负责人'}` }]}><ContactsInput config={{ key: 'holderEmployeeCode' }} />
</TypographyForm.Item>

原因

antd官方为了尽量少造成多余的渲染,把这个主动权交由开发者自己来实现,适配更多场景,得到相对优秀的渲染性能

解决代码

const onInOutTypeChange = (val) => {setInOutType(val);// 清除指定字段的规则form.setFieldsValue({ holderEmployeeCode: '' });handleValidateFields();};const handleValidateFields = () => {form.validateFields(['holderEmployeeCode']).then((values) => {// 校验成功后的操作console.log('校验通过', values);}).catch((errorInfo) => {// 校验失败后的操作console.log('校验失败', errorInfo);});};
http://www.lryc.cn/news/114845.html

相关文章:

  • Rocketmq Filter 消息过滤(TAGS、SQL92)原理详解 源码解析
  • Attacks in NLP
  • 04-7_Qt 5.9 C++开发指南_QTreeWidget和QDockWidget
  • Keburnetes YAML配置文件管理
  • opencv基础-33 图像平滑处理-中值滤波cv2.medianBlur()
  • 后端进阶之路——深入理解Spring Security配置(二)
  • 怎么绘制汤姆索亚历险记思维导图?掌握这几个绘制步骤就可以
  • Redis和数据库更新先后顺序
  • JavaScript--AJAX
  • AI Chat 设计模式:13. 代理模式
  • 嵌入式开发实用工具——QFSViewer
  • appium自动爬取数据
  • jenkins 在pinline克隆代码的两种方式
  • Python入门【​编辑、组合、设计模式_工厂模式实现 、设计模式_单例模式实现、工厂和单例模式结合、异常是什么?异常的解决思路 】(十七)
  • 65 # 实现 http-server 里的 gzip 压缩
  • 点成分享丨qPCR仪的原理与使用——以Novacyt产品为例
  • Postman如何做接口测试
  • 每天一道leetcode:剑指 Offer 32 - II. 从上到下打印二叉树 II(适合初学者)
  • vue动态生成行
  • IPC之一:使用匿名管道进行父子进程间通信的例子
  • 前端将页面转化为图片---进行下载导出、打印等功能
  • docker安装code-service在线开发vscode工具及node版本过低问题
  • C++ 多态深入解析
  • C#使用EmguCV播放视频
  • LeetCode150道面试经典题-买卖股票的最佳时机(简单)
  • 【积水成渊】CSS磨砂玻璃效果和渐变主题色文字
  • JVM、JRE、JDK三者之间的关系
  • input 标签的 type 属性有哪些值?分别表示什么意思?
  • (十五)大数据实战——hive的安装部署
  • MySQL安装和卸载