这是我的子组件,需要将数据传递给其父组件。
class Sidebar extends React.Component {
getUserInput(event){
event.preventDefault();
let value = document.getElementById('input-button').value;
console.log(value);
this.props.handleSubmit(value);
}
render() {
return (
<div>
<input type="text" id="input-button" placeholder="YGUID" />
<button type="button" className="btn btn-info btn-icons" onClick={this.getUserInput} />
</div>
);
}
}
Sidebar.propTypes = {
handleSubmit: React.PropTypes.func
};
这是父调用handleSubmit的地方。
......
handleSubmit(data){
console.log(data);
}
render(){
return(
<div className="col-md-2 left-pane">
<Sidebar handleSubmit= {this.handleSubmit}/>
</div>
);
}
我收到以下错误。
Uncaught TypeError: Cannot read property 'props' of null
我在这里做错了什么。
答案 0 :(得分:1)
this.getUserInput
道具的 Sidebar
函数在调用时不会绑定到正确的上下文(this
)。例如,您可以bind:
<Sidebar handleSubmit={this.handleSubmit.bind(this)}/>
还有其他选择如何解决这个问题。例如,使用具有词法this
的箭头函数,构造函数中的绑定方法或使用类属性来定义具有箭头函数的方法(ES7)。