首页 文章

潜在的未处理拒绝[1] TypeError:无法读取未定义的属性'setState'

提问于
浏览
0

我尝试使用ReactJS更新状态时看到以下错误,尽管已经绑定了该函数 . 代码如下所示 . 方法绑定,console.log显示api正在返回正确的数据 .

潜在的未处理拒绝[1] TypeError:无法读取undefined`的属性'setState'

import React from 'react';
import {BootstrapTable, TableHeaderColumn} from 'react-bootstrap-table';

var rest, mime, client;

rest = require('rest');
mime = require('rest/interceptor/mime');

import ParameterDialog from './parameter-dialog';

const categoryAvailable = {
    'POS': 'POS'
};

const options = {
    noDataText: 'No parameters founds.'
}

function enumFormatter(cell, row, enumObject) {
    return enumObject[cell];
}

export default class ParameterContainer extends React.Component {

    constructor(props) {
        super(props);
        this.state = { parameters: [] };
        this.client = rest.wrap(mime);
        this.fetchFromApi = this.fetchFromApi.bind(this);
    }

    fetchFromApi() {
        this.client({ path: '/api/parameters' }).then(function(response) {
            console.log(response);
            console.log(response.entity);
            this.setState( {parameters: response.entity} );
        });
    }

    componentDidMount() {
        this.fetchFromApi();
    }

    render() {
        return (
            <div>
                <h2>Parameters</h2>
                <ParameterDialog />
                <BootstrapTable data={this.state.parameters} options={options} pagination>
                    <TableHeaderColumn isKey dataField='id'>ID</TableHeaderColumn>
                    <TableHeaderColumn dataField='category' filterFormatted dataFormat={enumFormatter} formatExtraData={categoryAvailable}
                        filter={{type: 'SelectFilter', options: categoryAvailable}}>Category</TableHeaderColumn>
                    <TableHeaderColumn dataField='subCategory'>Sub Category</TableHeaderColumn>
                    <TableHeaderColumn dataField='parameter' filter={ { type: 'TextFilter', delay: 500 } }>Parameter</TableHeaderColumn>
                    <TableHeaderColumn dataField='type' filterFormatted dataFormat={enumFormatter} formatExtraData={this.props.parentState.parameterTypes}
                                       filter={{type: 'SelectFilter', options: this.props.parentState.parameterTypes}}>Type</TableHeaderColumn>
                    <TableHeaderColumn dataField='roles'>Roles</TableHeaderColumn>
                </BootstrapTable>
            </div>
        )
    }
}

2 回答

  • 1

    你的内部函数.then也必须绑定

    您可以使用()=>语法

    fetchFromApi() {
            this.client({ path: '/api/parameters' }).then(response => {
                console.log(response);
                console.log(response.entity);
                this.setState( {parameters: response.entity} );
            });
        }
    

    或者只是绑定函数

    fetchFromApi() {
            this.client({ path: '/api/parameters' }).then((function(response) {
                console.log(response);
                console.log(response.entity);
                this.setState( {parameters: response.entity} );
            }).bind(this);
        }
    
  • 1

    看起来setState是在 promise.then 的上下文中调用的,而不是类 . 快速解决方法是将其更改为箭头功能,如:

    .then(response => {
        console.log(response);
        console.log(response.entity);
        this.setState( {parameters: response.entity} );
    });
    

相关问题