【发布时间】:2018-07-15 21:12:33
【问题描述】:
我正在构建一个搜索引擎(使用 React.js),我可以在其中使用他们的 API 查找 GIPHY gif。我是 React.js 的新手,我在正确获取此代码时遇到了一些麻烦。
import React from 'react'; //react library
import ReactDOM from 'react-dom'; //react DOM - to manipulate elements
import './index.css';
import SearchBar from './components/Search';
import GifList from './components/SelectedList';
class Root extends React.Component { //Component that will serve as the parent for the rest of the application.
constructor() {
super();
this.state = {
gifs: []
}
}
handleTermChange(term) {
console.log(term);
//---------------------->
let url = 'http://api.giphy.com/v1/gifs/search?q=${term}&api_key=dc6zaTOxFJmzC';
fetch(url).
then(response => response.json()).then((gifs) => {
console.log(gifs);
console.log(gifs.length);
this.setState({
gifs: gifs
});
});//<------------------------- THIS CODE HERE
};
render() {
return (
<div>
<SearchBar onTermChange={this.handleTermChange} />
<GifList gifs={this.state.gifs} />
</div>
);
}
}
ReactDOM.render( <Root />, document.getElementById('root'));
我在控制台中收到以下错误: Uncaught (in promise) TypeError: _this2.setState is not a function 在 eval (index.js:64) 在
感谢任何帮助 :) 谢谢!
【问题讨论】:
-
在构造函数中使用
{this.handleTermChange.bind(this)}或添加this.handleTermChange = this.handleTermChange.bind(this)。
标签: javascript reactjs fetch-api