- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
React 有上下文的原因是允许多个兄弟组件共享一个状态数据。这是允许两个不相关的组件在共享变量中读/写的首选方法。之所以有必要,是因为 React 无法在不实际在屏幕之间传递数据的情况下轻松地将数据值提供给多个屏幕。相反,它允许每个屏幕在需要时访问数据。
所以... 实现需要创建一个组件,称为 Context.Provider
组件,然后您必须将需要访问共享数据的组件包装在 中上下文提供者
。但为什么?为什么这是一个要求? Context
旨在在层级关系不相关的组件之间共享数据,是否需要将组件置于层级结构中才能这样做?
简单地放弃使用 Context.Provider 的要求会简单 100 倍并且同样有效,简单地让 useContext
函数默认提供对设置变量的访问:
// In ctx.js
import React from 'react';
export default CTX = React.createContext({val: "value"});
// In compA.js
import CTX from './ctx.js';
import {useContext} from 'react';
function A(props) {
var [context, setContext] = useContext(CTX);
console.log(context); //Logs {val: 'value'};
setContext({val: "newValue"});
}
然后,假设组件 B 在 A 之后呈现:
import CTX from './ctx.js';
import {useContext} from 'react';
function B(props) {
var [context, setContext] = useContext(CTX);
console.log(context); //Logs {val: 'newValue'};
}
上面的用法,如果真的有效,解决了“在不相关的组件之间共享数据”的任务,并且比要求在上下文文件中定义一个全新的组件要简单得多。这个解决方案更好,因为:1. 无需重组申请。您不需要将组件包装在提供者中。2.任何组件都可以轻松地请求任何共享状态,并且可以轻松地设置共享状态。3. 代码更少,更容易理解(一行代码用于导入,一行代码用于启动上下文)。4. 不牺牲任何东西。这种方法允许在组件之间轻松共享状态,这首先是上下文的全部原因。
我疯了吗?我们绝对需要将我们的组件包装在一个特殊的组件中以共享数据是否有正当理由?..为什么共享状态不能独立存在?好像他们选择了一个糟糕的解决方案……为什么让每个开发人员在使用共享状态之前将组件包装在另一个组件中,为什么不让开发人员在需要使用该死的共享状态时使用它而不是跳过一个箍?有人请教我。
编辑:一个答案说,使用我描述的方法,我们将无法使用单个组件访问多个上下文。那是错误的。使用我描述的方法实际上更容易:
// In context.js
export const CTX = React.createContext({val: "val"});
export const CTX2 = React.createContext({val2: "val2"});
// In app.js
function App(props) {
const [state, setState] = useContext(CTX);
const [state2, setState2] = userContext(CTX2);
return (<></>);
}
简单。不需要 Context.Provider
。这是在一个组件中使用多个上下文,只需要两次调用 useContext 而不是将整个应用程序包装在两个嵌套的上下文中,这是您必须使用当前 Context.Provider
方法做的事情。 .
最佳答案
伙计,答案很简单。 React 组件仅在 props 或 state 发生变化时才重新渲染。如果没有 Context.Provider,组件 React 将永远无法理解何时重新渲染子组件,因此您将拥有陈旧的、渲染受阻的组件。
关于javascript - 为什么 React Context.Provider 是必需的(或有用的)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59012447/
我正在尝试加载外部 SVG 并将其附加到 Electron 项目中的现有 SVG。 d3.xml 方法对我不起作用,所以我正在查看 d3.symbols ,希望如果我提供路径数据(来自 fs.read
我正在编写一个 Web 应用程序,使用 Go 作为后端。我正在使用这个 GraphQL 库 (link)和 Echo Web 框架 (link) .问题在于 graphql-go 库在 Go 中使用了
有没有办法改造 gin.Context至 context.Context在围棋?构建 Go 微服务应该使用什么? 最佳答案 标准库的 context.Context type 是一个接口(interf
如果我能够像这样注册一个接收器: LocalBroadcastManager.getInstance(this).registerReceiver(mMessageReceiver, new Inte
如果我有 appengine.Context 而不是 ,我不知道如何调用 cloud.WithContext 和 google.DefaultClient >上下文。上下文。 有(旧的)“appeng
有什么区别- AccountManager accountManager = (AccountManager) context.getSystemService(Context.ACCOUNT_SER
我刚读了这篇文章:Build You Own Web Framework In Go为了在处理程序之间共享值,我选择了 context.Context我通过以下方式使用它在处理程序和中间件之间共享值:
在 Visual Studio Code 中,我对 3 个“上下文”菜单项感到非常困惑:Run Tests in Context和 Debug Tests in Context和 Run .NET C
我正在使用带有 和 @Autowired 的 Spring 2.5.6 版本。 虽然我在调度程序上下文中使用 SimpleUrlHandlerMapping ,但一切正常 - Autowiring 工
我使用的是 Context.registerReceiver()、Context.sendBroadcast(Intent) 和 Context.unregisterReceiver() 但是当我看到
问题在于以下错误, [错误] 在 scala.tools.nsc.typechecker.Typers$Typer.typedApply$1(Typers.scala:4580)[错误] 在 scal
最近我正在尝试使用 SoundPool 在我的应用程序中播放一些简单的音效 但不幸的是它在 AVD 中不起作用并且应用程序崩溃 “上下文”到底是什么意思? 完全不懂 提前致谢 最佳答案 任何上下文都允
我正在使用上下文建议器,我想知道我们是否可以设置用于建议的上下文范围,而不是使用所有上下文。 目前查询需要匹配所有上下文。我们能否在上下文中添加“或”运算和/或指定用于特定查询的上下文? 以here为
我被一个使用这种方法的函数卡住了。所以我知道如何使用 expressionValue(with:context:) 函数,但上下文如何参与对我来说仍然是不透明的。也许有人有简单的例子? try tra
我正在尝试在上下文管理器中更改我的 python 程序中的目录。使用 invoke.context.Context 似乎是正确的方法,从 Fabric 文档中获取并且使用常规 with os.chdi
我最近开始使用 Android Studio 处理我的 Android 项目。我注意到在 IDE 的右下角,有文本 Context: .好奇心打败了我,所以现在我正在网上搜索更多信息。我还没有找到任
假设我有这些功能: func A(ctx context.Context) { // A takes some time to process } func B(ctx context.Con
所以,我有一个 context.Context( https://golang.org/pkg/context/ ) 变量,有没有办法列出这个变量包含的所有键? 最佳答案 可以使用不安全反射列出 co
我正在尝试找出传播 context.Context 的正确方法用于在使用 Gin 时使用 OpenTelemetry 进行跟踪。 我目前有一个 gin调用函数并传递 *gin.Context 的处理程
我们可以使用 Remove["context`*"] 删除特定上下文中的所有符号。 .但是是否可以删除 "context`"自己从系统中删除,以便它不再在 Contexts[] 中列出? 最佳答案 据
我是一名优秀的程序员,十分优秀!