访问子组件是指从父组件内部访问子组件

Accessing child component refs from within a parent component

本文关键字:组件 访问 内部      更新时间:2023-09-26

我正在创建一个简单的React应用程序,它基于搜索从OMDb API加载电影数据-到目前为止,一切顺利。

然而,我重构了应用程序,并在父容器组件中添加了数据获取逻辑。现在我有麻烦通过refs容器组件访问搜索字段的值。

我的组件层次结构是这样的(每个组件在自己的文件中):

例子

stateprops似乎很好,正在正确地通过。这是主组件的JS——我使用axios从API获取数据:

class MovieSearchContainer extends Component {
  constructor(props) {
    super(props);
    this.state = {
      Search: [] 
    };
    this._performSearch = this._performSearch.bind(this);
  }
  _performSearch() {
    var _this = this;
    let query = I WANT TO ACCESS THE SEARCH FIELD VALUE HERE, maybe?;
    this.serverRequest = 
      axios
        .get(`http://www.omdbapi.com/?s=${query}&r=json`)
        .then(function(result) {    
          _this.setState({
            Search: result.data.Search
          });
        }) 
    .catch((error) => {
      console.log('Error fetching and parsing data', error);
    });
  }
  render() {
    return(
      <Application query={this.state.Search}
                   onSearch={this._performSearch} />
    );
  }
}
ReactDOM.render(<MovieSearchContainer />, document.getElementById('app'));
然后,进一步嵌套,我有一个<SearchForm />组件与以下JS:
class SearchForm extends Component {
  constructor() {
    super();
    this.state={
      searchText: ''
    };
  }
  _onSearchChange(e) {
    const searchText = e.target.value;
    this.setState({ searchText: searchText });
  }
  _handleSubmit(e) {
    if (e) e.preventDefault();
    this.props.onSearch(this.state.Search);
  }
  render() {
    return (
      <form className="search-form" onSubmit={this._handleSubmit.bind(this)} >
        <label className="is-hidden" for="search">...</label>
        <input type="search" 
               onChange={this._onSearchChange.bind(this)}
               name="search" 
               ref="query"
               placeholder="Search a Title..." />
        <button type="submit" id="submit" className="search-button">...</button>
      </form>      
    );
  }
}

最大的问题是:我如何从<MovieSearchContainer />内访问<SearchForm />inputref(或值),以便我可以将该值传递给API调用?

 // MovieSearchContainer
  _performSearch() {
    var _this = this;
    let query = I WANT TO ACCESS THE SEARCH FIELD VALUE HERE, maybe?;
    this.serverRequest = 
      axios
        .get(`http://www.omdbapi.com/?s=${query}&r=json`)
        .then(function(result) {    
          _this.setState({
            Search: result.data.Search
          });
        }) 
  }

我应该把这个逻辑放在其他地方吗?

我试过ReactDOM.findDOMNode(this.refs.query).value和其他一些方法,但没有运气。

请让我知道,如果你需要我提供更多的代码。:)

UPDATE:我将相同的ref值传递给每个子组件,包括我试图瞄准的input。例如:

// component hierarchy
<Application />
  <Header onSearch={this._performSearch} ref="query" />
    <SearchForm onSearch={this.props.onSearch} ref="query" />
      <input ... ref="query" />

我在容器组件中调用this.refs.query.value,它只针对渲染子组件的最外层元素。

因此,我为每个组件传递了一个不同的ref值,包括input节点:
<Header onSearch={this._performSearch} ref="header" />
  <SearchForm onSearch={this.props.onSearch} ref="searchform" />
    <input ... ref="query" />

然后,在我的_performSearch()方法中,我像这样定位input值:

_performSearch() {
  var query = this.refs.header.refs.searchform.refs.query.value;
  this.serverRequest = 
    axios
      .get(`http://www.omdbapi.com/?s=${query}&r=json`)
      ...
}

它工作得很好,但是看起来有点代码臭。有更简洁的建议吗?:)