状态在ReactJS中无法正常工作

时间:2017-06-04 14:07:14

标签: javascript reactjs

我要做的是,将输入字段值存储到状态然后,如果用户单击“保存”按钮或“存储”按钮,则输入字段将消失,因此编辑将为false.I&#39 ;当用户点击保存按钮时,我试图检查状态长度。问题出在那里。它说出了这个错误:Uncaught TypeError: Cannot read property 'state' of null,但我已经将数据存储在editData状态,为什么请你告诉我?

以下是更好理解的代码

class EditData extends Component {
    constructor(props) {
        super(props);
        this.handleChange = this.handleChange.bind(this);
        this.state = {
            editData: ''
        }
    }
    handleChange(e) {
        this.setState({editData: e.target.value})
    }

    save() {
        if (this.state.editData.length !== 0) {
            this.setState({isEditing: false});
            console.log(this.state.editData + 'Added on your database')
        } else {
            alert('Hahah Are you')
        }
        // console.log(this.refs.valTo.value);
    }
    render() {
        return (
            <div>
                <input onChange={this.handleChange} type="text" defaultValue={this.props.data}  /> <button onClick={this.save}>Save</button> <button>cancel</button>
            </div>
            );
    }
}

1 个答案:

答案 0 :(得分:5)

您需要绑定handleChangesave。 还要检查是否在构造函数中初始化了state

在构造函数中执行:

this.handleChange = this.handleChange.bind(this);
this.save= this.save.bind(this);
this.state = {};