微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React Context:嵌套重用/增强反模式?

如何解决React Context:嵌套重用/增强反模式?

我想知道创建嵌套上下文提供程序(相同的上下文)并逐步扩展数据是否是一种反模式。因此,使用当前上下文并从该点向下丰富/覆盖它。

这种方法有明显的(对我来说还没有)缺点吗?

是否有我可能遗漏的相关术语,以便搜索更多信息?

为什么

我正在为产品构建一种 ABAC 系统。此访问可能会受到可用于特定项目的不同项目的影响。

方法

const AuthContext = React.createContext({});

const AuthContextProvider = ({ children,value }) => {
  const parentAuth = React.useContext(AuthContext);
  const updatedAuth = { ...parentAuth,...value };

  return (
    <AuthContext.Provider value={updatedAuth}>{children}</AuthContext.Provider>
  );
};

我的用法类似于

<AuthContextProvider value={{ user }}>
  <SomeConsumingComponent permission="RE_ORDER" />
...    
  <AuthContextProvider value={{ question: question1 }}>
    <SomeConsumingComponent permission="EDIT_TEXT" />
  </AuthContextProvider>
....
  <AuthContextProvider value={{ question:question2 }}>
    <SomeConsumingComponent permission="MODIFY_MEDIA" />
  </AuthContextProvider>
</AuthContextProvider>

当然,消费组件可以出现在更复杂的结构中,我想在更高的可用点添加相关的“额外”数据。

解决方法

看起来他们正在测试您在此处描述的场景:

https://github.com/facebook/react/blob/2bf4805e4bd63dab45cd7f5e1ad32ef8fed3f6ab/packages/react-reconciler/src/__tests__/ReactNewContext-test.js#L277-L331

请注意,它们正在使用 Provider 中的上下文并改变值(第 286 行)。

既然他们期待这种用法,我看不出有任何理由认为这是一种反模式。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?