返回介绍

如何创建 refs?

发布于 2024-08-09 20:39:58 字数 1165 浏览 0 评论 0 收藏 0

这里有两种方案

  1. 这是最近增加的一种方案。Refs 是使用 React.createRef() 方法创建的,并通过 ref 属性添加到 React 元素上。为了在整个组件中使用refs,只需将 ref 分配给构造函数中的实例属性。
class MyComponent extends React.Component {
constructor(props) {
  super(props)
  this.myRef = React.createRef()
}
render() {
  return <div ref={this.myRef} />
}
}
  1. 你也可以使用 ref 回调函数的方案,而不用考虑 React 版本。例如,访问搜索栏组件中的 input 元素如下:
class SearchBar extends Component {
  constructor(props) {
    super(props);
    this.txtSearch = null;
    this.state = { term: '' };
    this.setInputSearchRef = e => {
        this.txtSearch = e;
    }
  }

  onInputChange(event) {
    this.setState({ term: this.txtSearch.value });
  }

  render() {
    return (
        <input
          value={this.state.term}
          onChange={this.onInputChange.bind(this)}
          ref={this.setInputSearchRef} />
    );
  }
}

你也可以在使用 closures 的函数组件中使用 refs

注意: 你也可以使用内联引用回调,尽管这不是推荐的方法。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文