React 的 useEffect 钩子,执行一些异步操作来加载基本信息

bash 复制代码
 useEffect(() => {
    (async () => {
      props.onLoad?.(true);
      const res = await onLoadBasic();
      const telephoneNo = await storage.get(TEL_CACHE_KEY);
      props.onLoad?.(false, res);
      const values = transformBasicInput(res, { telephoneNo, redo });
      props.form.formRef?.reset?.(values);
    })();
  }, [props.form.formRef, redo]);

1、代码解析

1、useEffect:

useEffect 是一个 React Hook,允许你在函数组件中执行副作用操作(例如数据获取、订阅或手动 DOM 操作)。

第二个参数是依赖数组,只有在这些依赖发生变化时,useEffect 才会重新执行。

2、自执行异步函数:

(async () => { ... })() 是一个自执行的异步函数,用于在 useEffect 中处理异步操作。

因为 useEffect 不能直接返回一个 Promise,所以需要使用自执行函数。

3、props.onLoad?.(true):

这是一个可选链调用,表示如果 onLoad 函数存在,则调用它并传入 true,通常表示开始加载数据。

4、const res = await onLoadBasic();:

调用 onLoadBasic 函数来异步获取基本信息,并将结果存储在 res 变量中。

5、const telephoneNo = await storage.get(TEL_CACHE_KEY);:

从某个存储(可能是本地存储或其他缓存机制)中获取电话号,存储在 telephoneNo 变量中。

6、props.onLoad?.(false, res);:

再次使用可选链,表示加载完成后调用 onLoad,传入 false 和获取的 res 结果。

7、 const values = transformBasicInput(res, { telephoneNo, redo });:

调用 transformBasicInput 函数,使用获取的基本信息 res 和其他数据(如 telephoneNo 和 redo)来转换输入值。

8、props.form.formRef?.reset?.(values);:

如果 formRef 和 reset 方法存在,调用 reset 方法,重置表单的值为 values。

2、依赖数组

  • props.form.formRef, redo\]: * useEffect 只有在 formRef 或 redo 发生变化时才会重新执行。这确保了在这些值改变时重新加载基本信息。

这段代码的主要功能是:

  • 在组件加载时异步获取基本信息和电话号。
  • 在加载过程中更新状态以指示加载状态。
  • 处理获取的数据并重置表单的值。这种处理方式使得- 组件在加载数据时能够有效地管理状态和用户界面。
相关推荐
我不吃饼干7 小时前
TypeScript 类型体操练习笔记(二)
前端·typescript
光影少年7 小时前
浏览器渲染原理?
前端·javascript·前端框架
小白探索世界欧耶!~8 小时前
Vue2项目引入sortablejs实现表格行拖曳排序
前端·javascript·vue.js·经验分享·elementui·html·echarts
GISer_Jing9 小时前
前端营销(AIGC II)
前端·react.js·aigc
漠月瑾-西安10 小时前
React-Redux Connect 高阶组件:从“桥梁”到“智能管家”的深度解析
react.js·设计模式·react-redux·高阶组件·connect高阶租单间·原理理解
NEXT0610 小时前
深度解析 JWT:从 RFC 原理到 NestJS 实战与架构权衡
前端·typescript·nestjs
程序员林北北11 小时前
【前端进阶之旅】节流与防抖:前端性能优化的“安全带”与“稳定器”
前端·javascript·vue.js·react.js·typescript
寻星探路11 小时前
【前端基础】HTML + CSS + JavaScript 快速入门(三):JS 与 jQuery 实战
java·前端·javascript·css·c++·ai·html
未来之窗软件服务12 小时前
未来之窗昭和仙君(六十九)前端收银台行为异常检测—东方仙盟练气
前端·仙盟创梦ide·东方仙盟·昭和仙君
大叔编程奋斗记13 小时前
两个日期间的相隔年月计算
前端·salesforce