🎶 Sym - 一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)平台

📕 思源笔记 - 一款桌面端笔记应用,支持 Windows、Mac 和 Linux

🎸 Solo - B3log 分布式社区的博客端节点,欢迎加入下一代社区网络

♏ Vditor - 一款浏览器端的 Markdown 编辑器

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 秒面试系列一


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

推荐阅读
留下你的脚步