this.changeContent
needs to be bound to the component instance via this.changeContent.bind(this)
before being passed as the onChange
prop, otherwise the this
variable in the body of the function will not refer to the component instance but to window
. See Function::bind.
When using React.createClass
instead of ES6 classes, every non-lifecycle method defined on a component is automatically bound to the component instance. See Autobinding.
Be aware that binding a function creates a new function. You can either bind it directly in render, which means a new function will be created every time the component renders, or bind it in your constructor, which will only fire once.
constructor() {
this.changeContent = this.changeContent.bind(this);
}
vs
render() {
return <input onChange={this.changeContent.bind(this)} />;
}
Refs are set on the component instance and not on React.refs
: you need to change React.refs.someref
to this.refs.someref
. You'll also need to bind the sendContent
method to the component instance so that this
refers to it.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…