首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React.js fetch Giphy

React.js fetch Giphy
EN

Stack Overflow用户
提问于 2018-02-05 22:08:52
回答 1查看 1.7K关注 0票数 2

我正在构建一个搜索引擎(和React.js),在那里我可以使用他们的API查找GIPHY。我是React.js新手,我在正确处理这个代码时遇到了一些困难。

代码语言:javascript
复制
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 (承诺) TypeError:_this2.setState不是上的 (index.js:64)函数

任何帮助都是感激的:)谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-02-05 22:12:31

this在ES6样式语法中不是自动绑定的.

您必须在构造函数中绑定:`超级();

代码语言:javascript
复制
this.state = {
    gifs: []
}
this.handleTermChange = this.handleTermChange.bind(this)```

或对所讨论的函数使用箭头函数语法:func = () => {};

参考:https://facebook.github.io/react/blog/2015/01/27/react-v0.13.0-beta-1.html#autobinding

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48632303

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档