首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在react js中接收更新的道具?

如何在react js中接收更新的道具?
EN

Stack Overflow用户
提问于 2018-12-11 08:11:56
回答 1查看 2.9K关注 0票数 1

你能告诉我如何在react js中接收更新的道具吗?我知道componentWillReceivePropsunsafe,我试过使用getDerivedStateFromProps,但没有工作

下面是我的代码https://codesandbox.io/s/rm30zoonk4

两秒钟后,我正在更新我的状态,该状态将传递给props

Expected output after two second

abcsssss

代码语言:javascript
复制
static getDerivedStateFromProps(nextProps, prevState) {
    if (nextProps.src !== "") {
      return { src: nextProps.src };
    } else return null;
  }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-11 08:24:42

您应该使用componentDidUpdate(prevProps、prevState)

每当组件处于接收新属性或内部状态时,componentDidUpdate都会被调用,您可以在组件重新呈现之前进行干预。

所以在hello.js中,而不是在getDerivedState中:

代码语言:javascript
复制
componentDidUpdate(prevProps) {
  if (prevProps.src !== this.props.src) {
    this.test()
  }
}

执行"if (prevProps.src !== this.props.src)“比较,以便组件仅在源属性发生更改时才更新,从而防止不必要的重新渲染。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53715608

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档