- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果允许以下三个选项中的任何一个,则找不到任何最近的官方信息?
constructor(props){
this.state={
item:<SomeItem/>,
item1:()=><SomeItem/>,
item2:SomeItem
}
}
我找到了 this回答但它引用了网络存档中的一个旧链接,上面写着:
What Shouldn’t Go in State?...React components: Build them in render()based on underlying props and state.
但是那个链接没有说明为什么这是个坏主意,它是否会引入错误等。
最佳答案
这是一个很好的问题。
不建议将组件置于状态的原因只是因为它从根本上违背了 React 模型,即组件提供了一个 render 方法(这是一个纯函数),React 引擎使用该方法来自动更新 DOM反射(reflect)组件的 Prop 和状态的值(value)。
该渲染的输出,即 React 元素,应该由 React 引擎直接使用。契约(Contract)是您的应用程序及其所有组件以一种纯粹的方式生成一堆元素,供 React 引擎管理。
通过在 render
中引入副作用,或将元素置于状态中,您实际上是在破坏“纯”契约,并且它可能会产生不可预测的结果,这可能会或可能不会被视为您的应用程序中的错误。错误的细节甚至可能随着不同版本的 React 和不同的引擎实现而改变。关键是你打破了 React 契约(Contract),所以虽然它在某些情况下可能有效,但在其他情况下甚至在 React 本身发生变化的情况下也可能无效。无法保证行为。
React 有内置的方法来缓存基于 prop 值的渲染,比如 React.memo
,引擎提供和理解,并且是契约的一部分。如果出于性能原因想要缓存渲染输出,可以采用这种方式。
确实,这正是 React API 提供此类功能而不是让您自己完成的原因。
关于javascript - 我可以将 React 组件放入 state 中吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62912502/
我试图在 Eclipse v3.7.2 中将 loopj .jar 库添加到我的项目中 首先,我将 .jar 添加到“lib”目录中,右键单击它并选择“添加到构建路径”。它编译得很好,但在执行时出现错
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Passing two-dimensional array via pointer int table[20
我在 Grafana 中的图表每隔几秒钟就会自动更新一次。随着数据的进入,右侧的最后一个数据点会暂时下降。最终会显示正确的值,但在几次更新时该值较低。这是正常的吗?可以修复吗? 最佳答案 也许,这会有
我不明白为什么我会收到臭名昭著的“IllegalStateException”以及以下代码: private void mergeQueryStrings(String url, Map parame
您好,我正在通过 .php 文件中的 JSON 回显将测试 Android 应用程序链接到 MySQL 数据库。 我能够用整个数据填充 ArrayList,但现在我想将数据分离到变量中,但我无法真正找
我想仅将对象的数据成员的值写入文件,因此这里我不能使用序列化,因为它会写入很多内容其他我不需要的信息。这是我通过两种方式实现的。一种使用字节缓冲区,另一种则不使用它。 不使用 ByteBuffer:第
可能是个简单的问题,但我似乎找不到答案。我正在动态创建一个页面,我可以在其中共享 Twitter 链接。 var twitter = document.createElement('a'); tw
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
尝试获取我在末尾为 $_SESSION 设置的值作为查询中的 user_id,而不是 $username。我似乎无法修改查询。我确信这对于这里的一些专家来说是非常简单的。 if(isset($_POS
有没有人可以帮助我,我有 mysql 查询,我已经在 phpmyadmin 中测试了它: select items.name, items.category, items.supplier_id, i
我正在尝试 push_back()一个„ std::vector 的符号. 我一直收到错误: character too large for enclosing character literal t
我有一个存储在 char * 中的压缩图像,我想将它放回 AVPacket,以便我可以将它放入 ffmpeg 解码器。有人可以展示如何做到这一点吗?任何示例或教程将不胜感激。 提前致谢 最佳答案 我向
password = str() while password != "changeme": password = input("Password: ") print("Thou Shall
所以我有一个 Map,其中有一些值被传递到一个方法中: public String doThis(Map context){ ..... } 我正在尝试向该 map 插入附加属性 String abc
我遇到了一些我无法弄清楚的问题...我正在编写一个带有接受拖放的 JList 的 Swing Java 应用程序。我想在将文件或文件夹从我的系统拖到 Java 应用程序上时更改光标。 最佳答案 我自己
我正在尝试确定一些关于如何编写异常消息的指南。 例如,让我们假设一个假设的函数必须接收恒定数量的字节(作为 bytes 对象),我们用 [1, 2, 3]。以下是所有可能的异常(exception)情
使用 JSONObject 发送到网络服务当我们将 double(整数)放入零时,该点将被删除 代码 double d = 123.00; JSONObject json = new JSONObje
在 WPF 中,如何将 DataGrid 放在 ComboBox 中以显示多列?像下面这样的东西似乎没有做任何事情:
我正在尝试使用自定义 QStandardItem 在两个 QListViews 之间进行拖放。 除了this document,我在网上找不到我需要的信息这有点帮助,但现在我被困住了。 从一个 QLi
如何将 PDF 放入 NSData 中?我在应用程序的文档目录中以字符串形式找到了 PDF 的位置。当我尝试通过电子邮件发送时,我在电子邮件正文中看到 PDF(而不是看到附件图标。我不知道这是否正常)
我是一名优秀的程序员,十分优秀!