2019-03-08
回答
callback refs 要优于 findDOMNode()
API,因为 findDOMNode()
阻碍了 React 在未来的改进。
// 使用 findDOMNode() 的传统方法
class MyComponent extends Component {
componentDidMount() {
findDOMNode(this).scrollIntoView()
}
render() {
return <div />
}
}
// 推荐使用 callback refs
class MyComponent extends Component {
componentDidMount() {
this.node.scrollIntoView()
}
render() {
return <div ref={node => (this.node = node)} />
}
}
加分回答
findDOMNode
可用于访问 DOM 下的节点。在大多数情况下,并不鼓励使用此 API,因为他违背了组件的抽象性。目前在StrictMode
中已经被弃用。- 除了 callback refs 外,还有 string refs,但已经不被推荐使用
class MyComponent extends Component {
componentDidMount() {
this.refs.node.scrollIntoView()
}
render() {
return <div ref="node" />
}
}