0

0

上下文、Redux 还是组合?

碧海醫心

碧海醫心

发布时间:2024-12-15 08:15:31

|

725人浏览过

|

来源于dev.to

转载

这篇文章最初发布于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”

结论

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

精美淘宝客单页面 zblog模板
精美淘宝客单页面 zblog模板

采用zblog修改的模板,简单方便,直接解压上传到空间即可使用,页面简单,适合SEO,导航,次导航,最新文章列表,随机文章列表全部都有,网站采用扁平结构,非常适用淘宝客类小站,所有文章都在根目录下。所有需要修改的地方在网页上各个地方都有标注说明,一切在网站后台都可以修改,无须修改任何程序代码,是新手的不二选择。后台登陆地址: 域名/login.asp用户名:admin (建议不要修改)密码:adm

下载

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

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

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

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


参考文献

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

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

20

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

28

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

149

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

120

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

14

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

23

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

168

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号