未捕获的TypeError:无法读取属性'道具'在React中为null

时间:2016-11-09 21:13:59

标签: javascript reactjs

这是我的子组件,需要将数据传递给其父组件。

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

我在这里做错了什么。

1 个答案:

答案 0 :(得分:1)

传递给this.getUserInput道具的

Sidebar函数在调用时不会绑定到正确的上下文(this)。例如,您可以bind

<Sidebar handleSubmit={this.handleSubmit.bind(this)}/>

还有其他选择如何解决这个问题。例如,使用具有词法this的箭头函数,构造函数中的绑定方法或使用类属性来定义具有箭头函数的方法(ES7)。