我不明白为什么我会收到此错误。我该如何解决,最重要的是为什么要得到它?

我从API返回了正确的响应,但在打电话后也得到了错误。

class App extends Component {

  constructor(props) {
    super(props);

    this.state = {
      movies: []
    };
  }

  videoSearch(term) {
    axios.get(`https://api.themoviedb.org/3/search/movie?api_key=${APIkey}&query=${term}&page=1`)
      .then(response => this.setState({movies: response.data.results}))
      .catch(err => console.log(err))
  };


  render() {
    return (
      <div className="App">
        <SearchBar onSearchTermChange={this.videoSearch} />
      </div>
    );
  }
}

export default App;



import React, {Component} from 'react';


class SearchBar extends Component {
    constructor(props) {
        super(props);

        this.state = { term: "" };
    }

    render() {
        return (
        <div className="search-bar">
            <input
            value={this.state.term}
            onChange={event => this.onInputChange(event.target.value)}
            />
        </div>
        );
    }

    onInputChange(term) {
        this.setState({ term });
        this.props.onSearchTermChange(term);
    }
}

export default SearchBar;

最佳答案

基于这类问题的大量猜测:)

尝试:

constructor(props) {
  super(props);

  this.state = {
      movies: []
  };

  this.videoSearch = this.videoSearch.bind(this);
}


告诉我是否可行。如果没有,我将删除答案。

我怀疑是与this组件调用的对象不同的对象。

关于javascript - TypeError:_this2.setState不是函数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/49541337/

10-09 17:35