搜索
首页开发工具composer大佬封装React Context Composer的详细步骤(分享)

本文由composer教程栏目给大家介绍大佬是如何一步步封装一个React Context Composer,希望对需要的朋友有所帮助!

我是如何一步步封装一个React Context Composer?

动机

React的状态管理方案有很多,比如Redux、Mobx、Recoil等,目前我只体验过Redux,觉得还是比较笨重一点。因为平时写Hooks比较多,所以我比较倾向于使用Context Provider配合useContext这个hook来做,这样也易于状态的拆分与组合。这里,我们不讨论各家状态管理方案的优劣,将目光聚焦于在使用Context时遇到的一个多层嵌套的问题。

下图,是我最近在写的一个taro + react hooks + ts项目抽离出来的一些代码。我对一些全局状态进行了拆分(拆分的目的是为了减少不必要的重新渲染),然后再把它们嵌套起来。这种写法让我回想起了曾经被回调地狱支配的感觉,很难受。因此,我想到了自己去封一个高阶组件,从写法上把结构“扁平化”。

<LoadingContext.Provider value={{ loading, setLoading }}>
  <UserDataContext.Provider value={{ name: "ascodelife", age: 25 }}>
    <ThemeContext.Provider value={"light"}>
    {/* ....more Providers as long as you want */}
    </ThemeContext.Provider>
  </UserDataContext.Provider>
</LoadingContext.Provider>

最易得的方案

这里,我很快的就写出了第一种方案,借助reduceRight去完成Provider的嵌套。

这里用reduceRight而不用reduce的原因是,我们更加习惯从外层到内层的书写顺序。

// ContextComposer.tsx
import React from &#39;react&#39;;
type IContextComposerProps = {
  contexts: { context: React.Context<any>; value: any }[];
};
const ContextComposer: React.FC<IContextComposerProps> = ({ contexts, children }) => {
  return (
    <>
      {contexts.reduceRight((child, parent) => {
        const { context, value } = parent;
        return <context.Provider value={value}>{child}</context.Provider>;
      }, children)}
    </>
  );
};
export default ContextComposer;
// App.tsx
<ContextComposer
  contexts={[
    { context: ThemeContext, value: "light" },
    { context: UserDataContext, value: { name: "ascodelife", age: 25 } },
    { context: LoadingContext, value: { loading, setLoading } },
  ]}>
    { children }
</ContextComposer>

实际体验后发现,虽然说能用是能用,但是开发体验差那么一点。它的问题在于,组件入参时传的value是any类型,这就意味着放弃了ts的静态类型检查。在传参时,由于不会对value做静态类型检查,敲起代码来不仅不会有任何代码提示,也有可能造成一些比较低级的运行时错误。差评!

基于React.cloneElement()的改造方案

为了改造上面的这种方案,我翻到了一个比较冷门但好用的函数—— React.cloneElement()。这个函数没有很多需要值得注意的点,主要看一眼它的三个入参,第一个是parent element,第二个是parent props,第三个是剩余参数...children,除第一个参数外,其他都是可选值。

举个例子:

<!-- 调用函数 -->
React.cloneElement(<div/>,{},<span/>);
<!-- 相当于创建了这样一个结构 -->
<div> 
    <span></span>
</div>

那么下面开始改造,reduceRight的架子不动,改一下入参的类型和reduceRight的回调。

// ContextComposer.tsx
import React from &#39;react&#39;;
type IContextComposerProps = {
  contexts: React.ReactElement[];
};
const ContextComposer: React.FC<IContextComposerProps> = ({ contexts, children }) => {
  return (
    <>
      {contexts.reduceRight((child, parent) => {
        return React.cloneElement(parent,{},child);
      }, children)}
    </>
  );
};
export default ContextComposer;
// App.tsx
<ContextComposer
  contexts={[
      <ThemeContext.Provider value={"light"} />,
      <UserDataContext.Provider value={{ name: "ascodelife", age: 25 }} />,
      <LoadingContext.Provider value={{ loading, setLoading }} />,
  ]}>
    { children }
</ContextComposer>

经过改造后,我们在传参时就好像是真的在创建一个组件(当然实际上也创建了组件,只是这个组件本身没有被渲染到虚拟Dom上,实际渲染上去的是被克隆后的副本)。同时,我们刚才关注的value的静态类型检查问题也得到了解决。

tips: React.cloneElement(parent,{},child)等价于React.cloneElement(parent,{children:child}),你知道为什么吗?

相关资源

源码已经同步到了github(https://github.com/ascodelife/react-context-provider-composer)。

同时也打包到了npm仓库中(https://www.npmjs.com/package/@ascodelife/react-context-provider-composer),欢迎体验。

以上是大佬封装React Context Composer的详细步骤(分享)的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:juejin。如有侵权,请联系admin@php.cn删除
作曲家的资格:评估能力作曲家的资格:评估能力Apr 24, 2025 am 12:15 AM

Composer使用熟练程度可以通过以下四个方面评估:1)理解基础概念,如包、依赖和版本控制;2)掌握核心功能,包括解析composer.json、解决依赖、下载包和生成autoload文件;3)熟练使用基本和高级命令,如composerinstall、update、require和dump-autoload;4)应用最佳实践,如使用composer.lock文件、优化autoload配置和定期清理缓存。

作曲家:利用AI进行自动任务作曲家:利用AI进行自动任务Apr 23, 2025 am 12:03 AM

使用Composer结合AI可以实现自动化任务。1.Composer通过配置文件管理依赖,AI可优化版本选择。2.在实际应用中,AI可用于自动化依赖管理、测试和部署。3.性能优化包括依赖加载和缓存策略。4.需注意版本冲突和AI误判等问题。通过这些方法,AI能提升工作效率和智能化程度。

与AI:代码建议和见解的作曲家与AI:代码建议和见解的作曲家Apr 22, 2025 am 12:05 AM

ComposerwithAI是利用AI提升编程体验的工具。1)它通过分析代码结构、语法和模式,提供实时建议和错误修复。2)高级功能包括代码重构、性能优化和安全性检查。3)使用时可调整配置、提供反馈和结合其他工具来解决常见问题。

作曲家:PHP依赖管理器的简介作曲家:PHP依赖管理器的简介Apr 21, 2025 am 12:02 AM

Composer是PHP的依赖管理工具,用于管理项目所需的库和包。1)它通过composer.json文件定义依赖,2)使用命令行工具进行安装和更新,3)自动化依赖管理过程,提高开发效率,4)支持高级功能如动态添加依赖和自动加载,5)通过composer.lock文件确保团队环境一致性。

作曲家的目的:有效地管理依赖关系作曲家的目的:有效地管理依赖关系Apr 20, 2025 am 12:04 AM

Composer是PHP的依赖管理工具,通过composer.json和composer.lock文件管理项目依赖。1.创建composer.json文件并运行composerinstall安装依赖。2.使用composerrequire添加新依赖。3.配置autoload实现类自动加载。4.使用composerdiagnose检查项目健康状况。5.优化依赖管理:指定包名更新,使用composerdump-autoload-o优化自动加载器,生产环境使用composerinstall--no-d

作曲家和AI:PHP开发中的新可能性作曲家和AI:PHP开发中的新可能性Apr 19, 2025 am 12:03 AM

AI与Composer结合可提升PHP开发效率和安全性。具体体现在:1.依赖解析和优化:AI可预测依赖关系,减少冲突。2.自动化安全检查:AI能识别安全漏洞,建议更新。3.代码生成和优化:AI能自动生成和优化相关代码。

使用DICR/YII2-Google将Google API集成在YII2中使用DICR/YII2-Google将Google API集成在YII2中Apr 18, 2025 am 11:54 AM

vProcesserazrabotkiveb被固定,мнелостольностьстьс粹馏标д都LeavallySumballanceFriablanceFaumDoptoMatification,Čtookazalovnetakprosto,kakaožidal.posenesko

如何使用 Composer 解决 JSON Schema 验证问题如何使用 Composer 解决 JSON Schema 验证问题Apr 18, 2025 am 11:51 AM

在开发一个基于Symfony的应用程序时,我遇到了一个棘手的问题:如何有效地验证JSON数据格式。最初,我尝试使用手动编写的验证代码,但这不仅复杂,而且容易出错。经过一番探索,我发现了一个名为ptyhard/json-schema-bundle的Composer包,它为我的项目带来了极大的便利和效率。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。