上下文、Redux 还是组合?

这篇文章最初发布于2023年2月23日@我的博客页面

我是受到最近科技公司裁员影响的开发人员之一。所以,我开始用 react 面试前端职位。

在其中一家公司,我在反应中遇到了一个经典的道具钻孔问题,
并被要求解决它。为了简单起见,给出的问题就像
这个:

export default function app() {  const [user, setuser] = react.usestate(null);  const handlelogin = () => setuser(userdetails);  return (    
company logo
{user ? ( ) : ( )}
);}function dashboard({ user }) { return (
);}function dashboardnav({ user }) { return (
);}function welcomeuser({ user }) { return
welcome {user.name}
;}function userrole({ user }) { return
role {user.role}
;}

正如您所观察到的,我们将 user 属性从 app 组件传递到
子组件welcomeuser 和userrole。中间组件 dashboard 和 dashboardnav 只是转发 props,并没有真正使用它。

上下文、Redux 还是组合?

这是 react 中的一个经典 prop 钻孔 问题。

有趣的是,面试官要求通过 react context api 来解决问题
或使用 redux。

通过 react 上下文解决

使用 context api 来解决这个问题,代码如下。

const usercontext = react.createcontext(undefined);export default function app() {  const [user, setuser] = react.usestate(null);  const handlelogin = () => setuser(userdetails);  return (    
company logo: context
{user ? ( ) : ( )}
);}function dashboard() { return (
);}function dashboardnav() { return (
);}function welcomeuser() { const user = react.usecontext(usercontext); return
welcome {user.name}
;}function userrole() { const user = react.usecontext(usercontext); return
role {user.role}
;}

我们正在创建 usercontext 并使用 provider 包装仪表板,以便
我们可以将我们想要的 props 传递给深度嵌套的子组件。这个解决方案
有效。

上下文、Redux 还是组合?

通过 redux 解决

所以,如果我们要走经典的 redux 路线,我们需要创建一个类似的
使用单个全局存储来构造和包装所有内容,其中包含用户
目的。

解决方案代码将包含大量样板文件,因为我们使用 redux 来
解决一个简单的问题。

我只是给出了下面代码的要点,但如果你真的想探索完整的
代码,在这里:用 redux 解决。

export default function app() {  return (                );}function reduxapp({ user, setuser }) {  const handlelogin = () => setuser(userdetails);  return (    
company logo: redux
{user ? : }
);}function dashboard() { return (
);}function dashboardnav() { return (
);}function welcomeuser({ user }) { return
welcome {user.name}
;}const mapstatetopropswelcomeuser = (state) => ({ user: state });const connectedwelcomeuser = connect(mapstatetopropswelcomeuser)(welcomeuser);function userrole({ user }) { return
role {user.role}
;}const mapstatetopropsuserrole = (state) => ({ user: state });const connecteduserrole = connect(mapstatetopropsuserrole)(userrole);

我们已经连接了需要访问全局状态的组件
存储在redux中。

我是怎么解决的

阅读了有关反应组合的内容后,我通过制作解决了问题
使用 children 道具,看起来像这样

export default function AppSolution() {  const [user, setUser] = React.useState(null);  const handleLogin = () => setUser(userDetails);  return (    
Company Logo
{user ? ( ) : ( )}
);}function Dashboard({ children }) { return
{children}
;}function DashboardNav({ children }) { return
{children}
;}function WelcomeUser({ user }) { return
Welcome {user.name}
;}function UserRole({ user }) { return
Role {user.role}
;}

如果你仔细想想,这是解决这个问题的简单方法,无需介绍
任何复杂性,如createcontext或react-redux。我们还获得其他好处,例如
作为

将来,如果我们在 dashboard 中引入任何状态并对其进行操作,我们的 dashboardnav 永远不会重新渲染。通过提供道具仅提供给所需的组件,我们拥有良好的可见性 用户的所有消费者,无需在组件(文件)之间导航 寻找他们。

这种模式并不新鲜,并且已经在 react 社区中讨论过了。一个这样好的演练是在 react 中使用组合来避免“prop drilling”

结论

但是,我收到面试官的反馈,是这样的

码上飞 码上飞

码上飞(CodeFlying) 是一款AI自动化开发平台,通过自然语言描述即可自动生成完整应用程序。

码上飞 138 查看详情 码上飞

受访者没有正确理解问题,无法提供预期的解决方案。

我猜原因要么是面试官没有意识到这种模式,要么是我选择以一种没有被要求的方式解决问题。

话虽如此,我现在有动力写更多关于 react 中有趣的模式,希望它能吸引更广泛的受众。

分享这篇文章让我知道您的想法。

参考文献

codesandbox 解决方案使用上下文之前 – react 文档在 react 中使用组合来避免“prop drilling”博客答案:react 渲染行为(大部分)完整指南博客回答:为什么 react context 不是“状态管理”工具(以及为什么它不取代 redux)

以上就是上下文、Redux 还是组合?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/385996.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 13:38:25
下一篇 2025年11月6日 13:39:18

相关推荐

  • 如何解码 Apache Parquet 数据

    本文将详细介绍如何从 API 接口获取 Apache Parquet 格式的数据,并将其解码为可读格式,例如 Pandas DataFrame。我们将探讨两种有效的解决方案,并提供相应的代码示例,帮助您轻松处理 Parquet 数据,并解决可能遇到的常见问题。重点在于正确处理 API 响应内容,并使…

    2025年12月14日
    000
  • python greenlet如何交替运行

    在 Python 中,greenlet 是一个轻量级的协程库,允许你在同一个线程内手动控制多个执行流的切换。要实现两个或多个 greenlet 交替运行,关键在于通过 switch() 和 parent 的方式显式地在它们之间跳转。 基本原理:greenlet 的切换机制 每个 greenlet 都…

    2025年12月14日
    000
  • Django REST Framework 序列化器中选择性字段验证策略

    本文探讨在 Django REST Framework 序列化器中,如何对特定字段进行选择性验证,以及如何在对象级别验证中排除或特殊处理某些字段。我们将重点介绍如何正确实现“至少一个可选字段存在”的逻辑,并利用字段级验证来管理特定字段的验证行为。 DRF 序列化器验证机制概述 Django REST…

    2025年12月14日
    000
  • Pybind11中C++函数修改Python传入列表元素的持久化问题及解决方案

    本文深入探讨了Pybind11在处理C++函数修改Python传入数据,特别是列表元素时可能遇到的持久化问题。通过对比单一对象引用和集合类型(如std::vec++tor)的传递机制,揭示了std::vector&无法持久化修改的原因。文章提供了核心解决方案:通过将集合元素作为指针(std:…

    2025年12月14日
    000
  • Ruff格式化技巧:利用魔法尾随逗号实现多行列表与参数布局

    本文将深入探讨Ruff格式化工具的magic-trailing-comma特性,展示如何通过在列表或函数参数的最后一个元素后添加一个尾随逗号,强制Ruff将其格式化为多行布局。这对于提升代码可读性,尤其是在处理Python的__all__变量或长参数列表时,具有重要意义。 在python开发中,代码…

    2025年12月14日
    000
  • PyTorch I3D模型在自定义数据集上的微调指南

    本文详细介绍了如何在PyTorch中对预训练的I3D模型进行微调,以适应具有不同输出类别的自定义数据集。文章着重讲解了如何正确地定位和修改模型的最终分类层,避免常见的AttributeError,并提供了两种修改模型结构的方法:直接替换原有分类层和追加新的分类层,旨在帮助开发者高效地完成模型适配。 …

    2025年12月14日
    000
  • PyCharm移动重构自动移除导入的处理指南

    PyCharm在执行文件移动重构时,除了更新导入路径外,还会自动移除被判定为未使用的导入语句。这一行为可能导致代码意外修改,且目前无法通过设置全局禁用。本文将深入探讨这一现状,并提供一种利用特定注释保护关键导入不被移除的临时解决方案,同时指出这是PyCharm的一个已知问题。 1. PyCharm移…

    2025年12月14日
    000
  • FastAPI中实现可切换的安全认证机制

    本文探讨如何在FastAPI应用中实现可动态切换的安全认证机制,尤其是在测试模式下禁用API密钥验证。通过条件性地应用FastAPI的Security依赖,开发者可以在不修改核心认证逻辑的情况下,灵活控制API端点的访问权限,从而简化开发和测试流程,提高开发效率。 1. 理解FastAPI的安全认证…

    2025年12月14日
    000
  • 如何在Python中实现不满足条件时重新获取输入

    本文旨在解决Python程序中,当用户输入不符合预设条件时,如何实现重新获取输入,而非直接结束程序或陷入无限循环的问题。通过while循环结合条件判断和重新输入,可以有效地确保用户输入的有效性,从而提高程序的健壮性和用户体验。 在编写Python程序时,经常需要根据用户的输入进行不同的处理。如果用户…

    2025年12月14日
    000
  • 针对逻辑上不可能发生的情况抛出异常是否合理?

    本文探讨了在逻辑上不可能发生的条件下抛出异常的做法是否合理。核心观点是,对于绝对不可能发生的情况,进行条件判断和抛出异常是多余的,反而会增加代码的复杂度和维护成本。而对于“不应该”发生但“可能”发生的情况,则需要根据潜在的损害程度来判断是否需要进行显式检查和处理。本文将通过具体示例,深入分析这一问题…

    2025年12月14日
    000
  • 优化结果舍入导致的约束不满足问题:浮点数精度处理策略与最佳实践

    本文探讨了在优化问题中,将高精度结果舍入到固定小数位数时,可能导致约束条件(如系数之和为1)不再满足的问题。文章分析了浮点数表示的本质,并提供了多种解决方案,包括启发式调整、敏感度分析以及采用浮点数十六进制格式进行精确数据交换等最佳实践,旨在帮助读者更优雅地处理此类精度挑战。 1. 问题描述:优化结…

    2025年12月14日
    000
  • TensorFlow TensorBoard日志的程序化解析与数据提取

    本文详细介绍了如何利用TensorFlow的EventFileReader API,以编程方式访问和解析TensorBoard生成的事件日志文件。通过此方法,用户无需依赖TensorBoard可视化界面,即可高效地提取训练过程中的步数、时间戳及标量指标值等关键数据,为进一步的数据分析和处理提供便利。…

    2025年12月14日
    000
  • Python Pandas:根据特定分隔符和全大写字符串拆分列

    本文介绍了如何使用 Python Pandas 库,根据特定分隔符(’ – ‘)以及分隔符后的全大写字符串,将 DataFrame 中的某一列拆分为两列。通过使用正则表达式和 str.extract 方法,可以高效地实现这一目标,并处理各种复杂的字符串组合。 Pa…

    2025年12月14日
    000
  • Python实现文本文件内容按N行分组处理

    本教程详细介绍了如何使用Python将文本文件的内容按指定行数(例如三行)进行高效分组。通过文件读取、循环迭代和列表切片等核心技术,实现将连续的文本行组织成独立的列表组,并妥善处理末尾不足指定行数的剩余部分,为后续数据处理提供清晰、可访问的结构化数据。 在处理文本文件时,我们经常需要将文件内容按照固…

    2025年12月14日
    000
  • 如何解决Streamlit在CMD中运行时的WinError 10013错误

    WinError 10013错误通常是由于端口冲突引起的,通过修改Streamlit的默认端口,可以有效解决此问题。 当你在CMD中运行Streamlit应用时,可能会遇到如下错误信息: PermissionError: [WinError 10013] An attempt was made to…

    2025年12月14日
    000
  • Streamlit WinError 10013 解决方案:深入理解与端口配置

    本文旨在解决Streamlit应用在Windows命令行运行中遇到的WinError 10013权限错误。该错误通常指向端口访问受阻,可能是端口被占用或权限不足。核心解决方案是通过创建.streamlit/config.toml文件,明确指定一个可用的服务端口,从而避免默认端口的冲突,确保Strea…

    2025年12月14日
    000
  • 从HTTP响应中高效保存Excel文件:Pandas与直接写入方法解析

    本文旨在指导读者如何高效地从HTTP响应的字节流 (response.content) 中保存Excel文件。我们将探讨两种主要方法:一是直接将字节流写入文件,适用于保存原始、完整的Excel文件;二是利用Pandas的ExcelFile对象解析并分别保存Excel中的各个工作表。通过示例代码和注意…

    2025年12月14日
    000
  • Selenium自动化操作GitHub搜索栏:解决元素不可交互问题

    本教程旨在解决使用Selenium自动化操作GitHub搜索栏时遇到的“元素不可交互”问题。通过深入分析GitHub搜索功能的DOM结构,我们发现需首先点击一个搜索按钮来激活真正的输入框,而非直接尝试向初始元素发送文本。文章将提供详细的步骤和代码示例,指导读者正确地定位、交互并成功执行搜索操作,并强…

    2025年12月14日
    000
  • Pandas高级数据合并:利用pd.concat处理日期时间列

    本文详细介绍了在Pandas中如何使用pd.concat函数来高效合并基于日期时间列的DataFrame。通过结合set_index和reset_index操作,我们可以将日期时间列转换为索引进行精确对齐,再利用pd.concat沿指定轴合并数据。这种方法为处理时间序列数据或需要基于索引进行合并的场…

    2025年12月14日
    000
  • FastAPI集成Azure AD OAuth2认证配置指南

    本文详细阐述了在FastAPI应用中集成Azure AD OAuth2认证时可能遇到的常见问题及其解决方案。主要聚焦于解决Authlib配置中TypeError: Invalid type for url错误,通过正确设置access_token_url和jwks_uri来确保OAuth客户端与Az…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信