我要做的是,将输入字段值存储到状态然后,如果用户单击“保存”按钮或“存储”按钮,则输入字段将消失,因此编辑将为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>
);
}
}
答案 0 :(得分:5)
您需要绑定handleChange
和save
。
还要检查是否在构造函数中初始化了state
。
在构造函数中执行:
this.handleChange = this.handleChange.bind(this);
this.save= this.save.bind(this);
this.state = {};