- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这就是我们使用componentWillReceiveProps
的方式
componentWillReceiveProps(nextProps) {
if(nextProps.myProp !== this.props.myProps) {
// nextProps.myProp has a different value than our current prop
}
}
它与componentDidUpdate
非常相似
componentDidUpdate(prevProps) {
if(prevProps.myProps !== this.props.myProp) {
// this.props.myProp has a different value
// ...
}
}
我可以看到一些差异,比如如果我在 componentDidUpdate 中执行 setState,render 将触发两次,而 componentWillReceiveProps 的参数是 nextProps,而 componentDidUpdate
的参数是 prevProp,但说实话,我不知道知道何时使用它们。我经常使用 componentDidUpdate
,但使用 prevState,例如更改下拉状态并调用 api
例如。
componentDidUpdate(prevProps, prevState) {
if(prevState.seleted !== this.state.seleted) {
this.setState({ selected: something}, ()=> callAPI())
}
}
最佳答案
两者的主要区别是:
状态
顾名思义 - 正如您提到的“如果我在 componentDidUpdate 中执行 setState,渲染将触发两次”,您可能也知道 - componentDidUpdate
在组件之后被调用更新(收到新的 Prop 或状态)。这就是为什么该函数的参数是 prevProps
和 prevState
的原因。
因此,如果您想在组件收到新 props 之前执行某些操作,则可以使用 componentWillReceiveProps,如果您想在组件收到新 props 之后执行某些操作,则可以使用 componentWillReceiveProps em> 它收到了新的 props 或状态,您可以使用 componentDidUpdate
。
状态
?这里的主要区别是:
componentWillReceiveProps
将更新状态 synchronously componentDidUpdate
将更新状态 asynchronously .这可能很重要,因为在尝试与组件 Prop 的其他部分同步状态时可能会出现一些问题。
关于javascript - React 中的 componentDidUpdate 与 componentWillReceiveProps 用例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49386324/
我最近购买了《C 编程语言》并尝试了 Ex 1-8这是代码 #include #include #include /* * */ int main() { int nl,nt,nb;
早上好!我有一个变量“var”,可能为 0。我检查该变量是否为空,如果不是,我将该变量保存在 php session 中,然后调用另一个页面。在这个新页面中,我检查我创建的 session 是否为空,
我正在努力完成 Learn Python the Hard Way ex.25,但我无法理解某些事情。这是脚本: def break_words(stuff): """this functio
我是一名优秀的程序员,十分优秀!