Ich habe diese Komponente:
import React from 'react';
export default class AddItem extends React.Component {
add() {
this.props.onButtonClick(this.input.value);
this.input.value = '';
}
render() {
return (
<div className="add-item">
<input type="text" className="add-item__input" ref={(input) => this.input = input} placeholder={this.props.placeholder} />
<button disabled={!this.input.value} className="add-item__button" onClick={this.add.bind(this)}>Add</button>
</div>
);
}
}
Ich möchte, dass die Schaltfläche deaktiviert wird, wenn der Eingabewert leer ist. Der obige Code funktioniert jedoch nicht. Es sagt:
add-item.component.js: 78 Nicht erfasster TypeError: Die Eigenschaft 'value' von undefined kann nicht gelesen werden
zeigen auf disabled={!this.input.value}. Was kann ich hier falsch machen? Ich vermute, dass ref möglicherweise noch nicht erstellt wurde, wenn die renderMethode ausgeführt wird. Wenn ja, wie lautet die Problemumgehung?
