反应,如何在更新DOM后立即获取元素的大小

时间:2019-01-24 02:28:10

标签: javascript reactjs

我想在更新道具后获取元素大小,因此我尝试通过componentDidUpdate()获取它,但是每次它为我返回0时

我编写了一个由其父组件控制的组件,在父组件中,调用了setState的语句,以更改我的组件的道具。

然后,我想在更改道具后立即在组件中获取一个div的大小,因此我将代码放在componentDidUpdate()中,但是clientHeight和getBoundingClientRect()都返回0,实际上,其高度和宽度肯定是不是0。

/*index.js*/
import React, { Component } from 'react'

class MyTL extends Component{
  constructor(props){
    super(props)
  }

  componentDidMount(){
    this.root = this.refs.tl
  }

  componentDidUpdate(){
    if(this.props.t){
      // this.root = this.refs.tl   // I tried to get root here, but not worked
      console.log(this.root.clientHeight)
      console.log(this.root.getBoundingClientRect())
    }
  }

  render(){
    return (
      <div className='tr_c', refs='tl'></div>
    )
}

/* style.less*/
.tr_c{
  height:100%;
  width:100%;
}

我希望控制台输出为“ 290px”,但它给了我0

在这里无法获得尺寸吗?请帮助我。

2 个答案:

答案 0 :(得分:0)

不确定是什么触发了componentDidUpdate(),但是使用componentDidMount()作为参考,我会像这样构造您的元素ref:

class MyTL extends React.Component {
  constructor(props) {
    super(props);
    this.tl = React.createRef();
  }

  componentDidMount() {
    console.log(this.tl.current.getBoundingClientRect());
    console.log(this.tl.current.clientHeight);
  }

  render() {
    return (
      <div className='tr_c' ref={this.tl}>
        <p>Stuff</p>
      </div>
    )
  }
}

ReactDOM.render(<MyTL />, document.querySelector("#app"));
.tr_c {
  background: #ccc;
  height: 250px;
  width: 100%;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="app"></div>

jsFiddle:https://jsfiddle.net/dzuwan13/

答案 1 :(得分:0)

我认为问题出在您的div

<div className='tr_c', refs='tl'></div>

没有内容,因此宽度/高度等于0。