javascript - this.setState 不是函数

标签 javascript reactjs ecmascript-6

<分区>

我有以下组件,它维护在特定元素上触发事件时更新的状态,当更新状态时,它作为 Prop 传递给另一个组件。我目前正在尝试为什么我会收到以下错误“this.setState 不是函数”,它很可能没有绑定(bind)到正确的上下文。但我不确定这一点,我这样做对吗?

export default class SearchBox extends Component{

    constructor(){
        super()
        console.log("search box imported");
        this.state = {
            results:[]
        };
    }

    //this.setState({result: arrayExample})

    searchGif(event) {
        if(event.keyCode == 13){
            let inputVal = this.refs.query.value;
            let xhr = new XMLHttpRequest();
            xhr.open('GET', 'http://api.giphy.com/v1/gifs/search?q='+inputVal+'&api_key=dc6zaTOxFJmzC', true);
            xhr.onreadystatechange = function(){
                if(xhr.readyState == 4 && xhr.status == 200){
                    // this.response = JSON.parse(xhr.responseText);
                    let returnedObj = JSON.parse(xhr.responseText);
                    //console.log(returnedObj.data);
                    let response = returnedObj.data.map(function(record){
                        let reformattedArray =  {   key: record.id,
                                                    id: record.id,
                                                    thumbnailUrl: record.images.fixed_height_small_still.url
                                                };
                                                return reformattedArray;
                    });
                    console.log(response);
                    this.setState({results: response});
                }
            }
            xhr.send();
        }
    }


    render(){

        return(
            <div>   
                <input className="search-input" ref="query" onKeyDown={this.searchGif.bind(this)} name="search" placeholder="Search"/>
                <GifSwatch data={this.state.results} />
            </div>
        );
    }
}

编辑: 我刚刚意识到上下文在“onreadyStateChange”函数时发生了变化,所以我在 searchGif 中做了以下操作

searchGif(){
   //other logic
   var self = this;
   xhr.onreadystatechange = function(){
    //ajax logic
    self.setState({results: repsonse});
   }
}

最佳答案

您正在丢失 React 类 this 上下文。绑定(bind)它,也在异步回调函数中绑定(bind)它。

constructor(props){
    super(props);
    console.log("search box imported");
    this.state = {
        results:[]
    };
    this.searchGif = this.searchGif.bind(this);
}

searchGif(event) {
    // ... code here
    xhr.onreadystatechange = () => {
    // ... code here
        this.setState();
    }
}

关于箭头函数的很棒的事情是它们为你绑定(bind)了你的上下文,而且语法也很棒。缺点是浏览器支持。确保你有一个 polyfil 或一个编译过程来将它编译成 ES5 语法以实现跨浏览器性能。

如果你不能做其中任何一个,那么只需在异步 onreadystatechange 函数之外为你的 this 上下文创建一个影子变量,并使用它代替 this


编辑

现在大多数编译器都使用箭头处理类的绑定(bind)方法(没有指定 babel 转换......等等),你也可以在没有构造函数的情况下以这种方式分配状态

export default class SearchBox extends Component {
  state = { 
    results: []
  }
  
  searchGif = (event) => {
    // ... code here
    xhr.onreadystatechange = () => {
    // ... code here
        this.setState();
    }
  }
  render() {
    // ...
  }
}

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

相关文章:

javascript - 基本react-rails组件中的语法错误

reactjs - 创建 react 应用程序.env : process not defined

PHPStorm JSX/React 语法高亮

javascript - 为什么yield不能解析promise?

javascript - 如何将 jquery 事件仅附加到外部 div?

Javascript:从 javascript 更改 <select ..> 选项

javascript - 在 JavaScript 类中抛出错误是否被认为是不好的做法?

javascript - ECMAScript 6 类析构函数

javascript - 使用按钮 reactjs 映射列表时出现“此”问题

javascript - 如何将外部驱动器、外部 js 文件链接到允许 JavaScript 的 WordPress 插件?