react 生命周期函数 componentDidMount 为什么不能保证可以拿到真实的dom?
问题:react 生命周期函数 componentDidMount 为什么不能保证可以拿到真实的dom?
示例代码:
componentDidMount(){
console.log(this.test) //大概率会得到null
}
render(){
return(
<div ref={(test) => {this.test = test}}>123<div>
)
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
回答
React 保证在
componentDidMount
和componentDidUpdate
之前设置refs
,但仅仅是在确定子组件已经渲染后。以下情况都有可能无法立即获取到 refs
1) 设置条件渲染
2)子组件包裹造成未渲染。
3) 使用 ReactDOM.render 嵌套渲染
总结出来就一句话:设置 ref 的组件或者元素渲染之后才能获取到对应的 ref
不是this.state.test么