问题:react 生命周期函数 componentDidMount 为什么不能保证可以拿到真实的dom?
示例代码:
componentDidMount(){
console.log(this.test) //大概率会得到null
}
render(){
return(
<div ref={(test) => {this.test = test}}>123<div>
)
}
问题:react 生命周期函数 componentDidMount 为什么不能保证可以拿到真实的dom?
示例代码:
componentDidMount(){
console.log(this.test) //大概率会得到null
}
render(){
return(
<div ref={(test) => {this.test = test}}>123<div>
)
}
10 回答11.3k 阅读
5 回答4.9k 阅读✓ 已解决
4 回答3.2k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
3 回答5.2k 阅读✓ 已解决
1 回答3.4k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
回答
React 保证在
componentDidMount
和componentDidUpdate
之前设置refs
,但仅仅是在确定子组件已经渲染后。以下情况都有可能无法立即获取到 refs
1) 设置条件渲染
2)子组件包裹造成未渲染。
3) 使用 ReactDOM.render 嵌套渲染
总结出来就一句话:设置 ref 的组件或者元素渲染之后才能获取到对应的 ref