问题: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>
)
}
13 回答13k 阅读
8 回答2.7k 阅读
2 回答5.1k 阅读✓ 已解决
5 回答1.3k 阅读
3 回答2.3k 阅读✓ 已解决
5 回答1.6k 阅读✓ 已解决
3 回答2.2k 阅读
回答
React 保证在
componentDidMount
和componentDidUpdate
之前设置refs
,但仅仅是在确定子组件已经渲染后。以下情况都有可能无法立即获取到 refs
1) 设置条件渲染
2)子组件包裹造成未渲染。
3) 使用 ReactDOM.render 嵌套渲染
总结出来就一句话:设置 ref 的组件或者元素渲染之后才能获取到对应的 ref