【react】记录一次react组件props依赖异步数据(setFieldsValue)后传递form给子组件,再逐层传递给孙子组件引起的未渲染异常

这篇具有很好参考价值的文章主要介绍了【react】记录一次react组件props依赖异步数据(setFieldsValue)后传递form给子组件,再逐层传递给孙子组件引起的未渲染异常。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

背景

react祖父组件设置异步数据(setFieldsValue)后传递form给子组件,再逐层传递给孙子组件引起的未渲染异常,孙子组件如果不设置useEffect和useState去监听value的值进行重渲染,会出现获取得到value最新值,但是不进行渲染的异常文章来源地址https://www.toymoban.com/news/detail-797219.html

解决前后的代码对比

完整代码(异常):
const GetText = (props) => {
  const { value, config, containerId, getFieldValue } = props;
  const [itemValue, setItemValue] = useState(value);
  const { formId } = config;
  const getFormId = useCallback(
    (suffix = '_param_countryPhoneCode') => {
      if (Array.isArray(formId)) {
        return [containerId, formId[0], `${formId[1]}${suffix}`];
      }
      return `${formId}${suffix}`;
    },
    [formId, containerId],
  );
  
  useEffect(() => {
    const pObj = getFieldValue(getFormId()) || {};
    if (!value.includes('+')) {
      const _itemValue = `${pObj.countryPhoneCode ? '+' : ''}${pObj.countryPhoneCode} ${value}`;
      setItemValue(_itemValue);
    }
  }, [getFieldValue, getFormId, value, getFieldValue(getFormId())]);

  return itemValue ? (
    <>
      <div style={{ fontSize: 12 }}>{itemValue}</div>
    </>
  ) : null;
};
完整代码(正常):
const GetText = (props) => {
  const { value, config, containerId, getFieldValue } = props;
  const [itemValue, setItemValue] = useState();
  const { formId } = config;
  const getFormId = useCallback(
    (suffix = '_param_countryPhoneCode') => {
      if (Array.isArray(formId)) {
        return [containerId, formId[0], `${formId[1]}${suffix}`];
      }
      return `${formId}${suffix}`;
    },
    [formId, containerId],
  );

  // 注意,由于在changeRecordModal中有对变更记录表单项做了顺序标记,
  // 因此formId会多一个序号,在变更记录弹窗里,首次加载可能因为更新是异步的导致value没有正常渲染,
  // 所以这边必须借用useEffect和useState控制value的更新渲染
  useEffect(() => {
    const pObj = getFieldValue(getFormId()) || {};
    if (!value.includes('+')) {
      const _itemValue = `${pObj.countryPhoneCode ? '+' : ''}${pObj.countryPhoneCode} ${value}`;
      setItemValue(_itemValue);
    }
  }, [getFieldValue, getFormId, itemValue, value]);

  return itemValue ? (
    <>
      <div style={{ fontSize: 12 }}>{itemValue}</div>
    </>
  ) : null;
};

到了这里,关于【react】记录一次react组件props依赖异步数据(setFieldsValue)后传递form给子组件,再逐层传递给孙子组件引起的未渲染异常的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 组件与Props:React中构建可复用UI的基石

    目录 组件:构建现代UI的基本单位 Props:组件之间的数据传递 Props的灵活性:构建可配置的组件 组件间的通信:通过回调函数传递数据 总结: 组件:构建现代UI的基本单位 组件是前端开发中的关键概念之一。它允许我们将UI拆分成独立、可复用的部分,使得代码更易于理解

    2024年02月06日
    浏览(40)
  • React类组件中super()和super(props)有什么区别?

    在ES6中,通过extends实现类的继承,如下: 通过super实现调用父类,super代替父类的构建函数,相当于调用sup.prototype.constructor.call(this,name),如果子类不适用super会报错,报错的原因是子类没有自己的this对象,他只是继承父类的this对象,然后对其加工,也不能

    2024年01月24日
    浏览(49)
  • React组件进阶之children属性,props校验与默认值以及静态属性static

    children 属性:表示该组件的子节点,只要组件有子节点,props就有该属性 children 属性与普通的 props 一样,值可以是任意值(文本、React元素、组件,甚至是函数) 核心代码 官网说明地址 对于组件来说,props 是外来的,无法保证组件使用者传入什么格式的数据 如果传入的数据

    2024年02月15日
    浏览(53)
  • 详解React antd中setFieldsValu的简便使用

    React是一个流行的JavaScript库,用于构建用户界面。它提供了一种简单而高效的方式来创建交互式的Web应用程序。而antd(Ant Design)是一个基于React的UI组件库,它提供了丰富的UI组件和样式,帮助开发者更快速地构建出美观的用户界面。 在React应用程序中,表单是常见的用户交

    2024年02月10日
    浏览(39)
  • 02react 函数组件useState的异步问题

    常见的钩子函数:useState、useEffect useState作为最常见的一个hook,在使用中总是会出现各种坑,最明显的就是 useState 更新异步的问题。 问题描述:把接口返回的数据,使用 useState 储存起来,但是当后面去改变这个数据的时候,每次拿到的都是上次的数据,无法实时更新。或者

    2024年02月03日
    浏览(47)
  • 【前端知识】React 基础巩固(三十四)——组件中的异步操作及优化

    通过组件的生命周期来完成网络请求,网络请求的异步代码直接放在组件中 通过redux来管理异步网络请求 在store中引入中间件 redux-thunk 构建 fetchHomeMultidataAction ,将原本在组件中的异步请求代码放入到actionCreators.js中 改写原来的category.jsx,派发异步请求的dispatch 查看运行结果

    2024年02月15日
    浏览(69)
  • Vue前端框架10 组件的组成、组件嵌套关系、组件的注册方式、组件传递数据(props $emit)、数组传递多种数据类型、组件传递props校验、组件事件

    组件最大的优势就是可复用性 通常将组件定义在.vue中,也就是SFC单文件组件 组件的基本组成: 组件允许我们将UI划分为独立的、可重用的部分,并且对每个部分单独思考 实际应用中组件常常被组件成层层嵌套的树状结构 Vue组件使用前要注册,注册有两种方式:全局注册和

    2024年02月09日
    浏览(50)
  • react 09之状态管理工具1 redux+ react-thunk的使用实现跨组件状态管理与异步操作

    npm install redux react-redux npm i redux-thunk redux-thunk redux-thunk是一个Redux的中间件,它允许你在Redux中编写异步的action creators。

    2024年02月13日
    浏览(49)
  • vue前端开发自学,父子组件传递数据,借助于Props实现子传父

    vue前端开发自学,父子组件传递数据,借助于Props实现子传父! 之前我们说过,Props这个是用在父传子的情况下,今天为大家介绍的代码,就是在父组件里,自定义事件,绑定一个函数,让子组件可以接受到这个自定义事件绑定的函数,从而“委婉”的传递数据给父组件。 如图

    2024年01月23日
    浏览(41)
  • 【react框架】结合antd做表单组件的一些心得记录

    作为一个前端最常遇见的需求场景就是写表单、写表格。写多了会逐渐的积累一些开发心得,此文章根据我使用vue和react的经验记录了一些东西,抛砖引玉的给大家看看。 举例react项目,在做表单的很多时候,我都是从antd上把其中一个form组件例子复制下来,然后再看看提供了

    2024年02月07日
    浏览(98)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包