Sym - 一个用 Java 实现的现代化社区平台 • 源码 • 注册

Pipe - 小而美的开源博客平台 • 体验 • 皮肤 Solo - 一个用 Java 实现的博客系统,为你或你的团队创建个博客吧! • 源码下载  Wide - 一个基于 Web 的 Go 语言 IDE • 教程试用

callback refs 和 findDOMNode() 之间哪一个更好?

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" />
  }
} 

返回总目录

30 秒面试系列一


欢迎注册黑客派社区,开启你的博客之旅。让学习和分享成为一种习惯!

留下你的脚步