其他分享
首页 > 其他分享> > Ant Design 中 resetFields 导致自定义组件销毁并重新加载问题分析

Ant Design 中 resetFields 导致自定义组件销毁并重新加载问题分析

作者:互联网

Form 中使用子组件的过程中发现,每次 resetFields 都会导致子组件销毁重建,而子组件由于要请求接口加载数据,所以会导致重复请求。本文记录相关 Issues 的查找过程和和相关源码分析

文章目录

一、现象说明

如下代码所示,每次子组件 FormChild 都会打 2 次 log,分析发现是 form.resetFields() 导致子组件重新加载了,而 form.setFieldsValue() 则不会导致组件重新加载

import React from "react";
import ReactDOM from "react-dom";
import { Form } from "antd";
import "antd/dist/antd.css";
import "./index.css";

ReactDOM.render(
  <div className="App">
    <FormDemo />
  </div>,
  document.getElementById("root")
);

function FormDemo() {
  const [form] = Form.useForm();

  React.useEffect(() => {
    form.resetFields();
  }, [form]);

  return (
    <Form form={form}>
      <Form.Item name="someitem">
        <FormChild />
      </Form.Item>
    </Form>
  );
}

function FormChild() {
  React.useEffect(() => {
    console.log("FormChild mounted");
  }, []);
  return <div>123</div>;
}

点击下方按钮运行代码:
Edit on CodeSandbox

二、官方解释

2.1 官方文档

为什么 resetFields 会重新 mount 组件?
resetFields 会重置整个 Field,因而其子组件也会重新 mount 从而消除自定义组件可能存在的副作用(例如异步数据、状态等等)。

可以看出官方是知道这个问题的,而且这是经过考虑之后的设计方案,所以平时使用的时候需要注意,有些时候更适合 set 而不是 reset
在这里插入图片描述

https://ant.design/components/form-cn/#%E4%B8%BA%E4%BB%80%E4%B9%88-resetFields-%E4%BC%9A%E9%87%8D%E6%96%B0-mount-%E7%BB%84%E4%BB%B6%EF%BC%9F

2.2 GitHub Issue

三、源码分析

antdform 的数据处理用了 rc-field-form,看代码都是 19 年 06 月写的

标签:自定义,form,resetFields,Ant,E4%,组件,import,antd
来源: https://blog.csdn.net/zhichaosong/article/details/114373300