加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

componentDidUpdate之后的绘制

发布时间:2020-12-15 06:34:21 所属栏目:百科 来源:网络整理
导读:componentDidUpdate 是更新版的 componentDidMount 方法。在这里可以处理本地的UI元素,可以操作 refs ,有需要的话也可以开启另外一个绘制过程。 componentDidUpdate 方法会传入两个参数: prevProps , prevState 。这个正好和 componentWillUpdate 是相对

componentDidUpdate是更新版的componentDidMount方法。在这里可以处理本地的UI元素,可以操作refs,有需要的话也可以开启另外一个绘制过程。

componentDidUpdate方法会传入两个参数:prevProps,prevState。这个正好和componentWillUpdate是相对的。这个两个参数的值就是在方法调用之前的this.propsthis.state

就如同componentDidMountcomponentDidUpdate在所有的子组件都更新之后被调用。如上图,A.0.0componentDidUpdate会先调用,然后是A.0的,最后才是A的。

如何使用

使用componentDidUpdate最一般的情况就是管理第三个的UI组件,以及和本地UI元素交互。比如你使用了Chart库之后:

componentDidUpdate(prevProps,prevState) {
  // 如果数据发生变化,则更新图表
  if(prevProps.data !== this.props.data) {
    this.chart = c3.load({
      data: this.props.data
    });
  }
}

在数据发横变化之后,更新图表

其他绘制过程

我们也可以查找本地的UI元素、获取大小和css的样式等。我们可以更新子组件。这时,可以调用this.setState或者forceUpdate。但是,这样也会引起很多的其他问题。

最糟糕的问题就是在没有检查条件的情况下直接调用setState方法:

componentDidUpdate(prevProps,prevState) {
  let height = ReactDOM.findDOMNode(this).offsetHeight;
  this.setState({
    internalHeight: height
  });
}

默认情况下shouldComponentUpdate方法返回的是true。所以,如果我们用了上面的方法,我们会进入无限循环的状态。

总的来说,一般不需要这么做。而且这样的重绘会造成性能问题。

原文地址:https://developmentarc.gitboo...

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读