ReactJS TypeError:无法读取undefined的属性'setState'

时间:2017-02-19 20:02:32

标签: javascript reactjs ecmascript-6 react-jsx

我正在尝试使用ReactJS更新组件的状态,但是收到以下错误。错误和代码如下。

潜在的未处理拒绝[1] TypeError:无法读取未定义的属性'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 parameterTypes = {
    'STRING': 'STRING',
    'BOOLEAN': 'BOOLEAN',
    'INTEGETR': 'INTEGETR',
    'DECIMAL': 'DECIMAL'
};

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);
    }

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

    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={parameterTypes}
                                       filter={{type: 'SelectFilter', options: parameterTypes}}>Type</TableHeaderColumn>
                    <TableHeaderColumn dataField='roles'>Roles</TableHeaderColumn>
                </BootstrapTable>
            </div>
        )
    }
}

3 个答案:

答案 0 :(得分:0)

问题似乎在于改变这种情况,你创建了Promise并试图改变它的状态。 this.fetchFromApi.bind(本)

答案 1 :(得分:0)

如果您使用stage-babel转换器,则需要使用箭头功能。

class ParameterContainer{
  fetchFromApi = () => {

  }
}

否则你可以将构造函数中的fetchFromApi函数绑定到此。

constructor(){
   this.fetchFromApi = this.fetchFromApi.bind(this)
}

答案 2 :(得分:-1)

编辑我的回答:

如果您正在使用babel,则可以使用https://babeljs.io/docs/plugins/transform-es2015-arrow-functions/,然后您不再需要绑定箭头功能