Quel est le modèle recommandé pour effectuer un setState sur un parent à partir d'un composant enfant.
var Todos = React.createClass({
getInitialState: function() {
return {
todos: [
"I am done",
"I am not done"
]
}
},
render: function() {
var todos = this.state.todos.map(function(todo) {
return <div>{todo}</div>;
});
return <div>
<h3>Todo(s)</h3>
{todos}
<TodoForm />
</div>;
}
});
var TodoForm = React.createClass({
getInitialState: function() {
return {
todoInput: ""
}
},
handleOnChange: function(e) {
e.preventDefault();
this.setState({todoInput: e.target.value});
},
handleClick: function(e) {
e.preventDefault();
//add the new todo item
},
render: function() {
return <div>
<br />
<input type="text" value={this.state.todoInput} onChange={this.handleOnChange} />
<button onClick={this.handleClick}>Add Todo</button>
</div>;
}
});
React.render(<Todos />, document.body)
J'ai un tableau d'articles à faire qui sont conservés dans l'état du parent. Je veux accéder à l'état du parent et ajouter un nouvel élément todo, à partir du composant TodoForm
s handleClick
. Mon idée est de faire un setState sur le parent, ce qui rendra l'élément todo nouvellement ajouté.