Liaison des inputs à un tableau dans React
Supposons que l'état notes contienne un tableau :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Supposons que nous ayons également une fonction utilitaire, qui calcule la somme des éléments du tableau :
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Calculons et affichons la somme des éléments de notre tableau d'état, en utilisant notre fonction utilitaire :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Créons maintenant trois inputs et dans le value
de chaque input, inscrivons un des éléments du tableau :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
<input value={notes[0]} />
<input value={notes[1]} />
<input value={notes[2]} />
{getSum(notes)}
</div>;
}
Ajoutons maintenant l'événement onChange
à nos inputs. Créons pour cela une fonction gestionnaire
commune pour cet événement :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// fonction gestionnaire commune
}
return <div>
<input value={notes[0]} onChange={event => changeHandler(0, event)} />
<input value={notes[1]} onChange={event => changeHandler(1, event)} />
<input value={notes[2]} onChange={event => changeHandler(2, event)} />
{getSum(notes)}
</div>;
}
Comme vous le voyez, la fonction changeHandler
prend comme premier paramètre le numéro de l'élément
du tableau que cet input modifie.
Grâce à ce numéro, nous pouvons remplacer l'élément du tableau par le contenu de l'input.
Faisons cela :
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Il sera maintenant possible de modifier n'importe quel input, le tableau changera de manière réactive et, par conséquent, la somme de ses éléments sera recalculée.
Rassemblons tout notre code :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
return <div>
<input value={notes[0]} onChange={event => changeHandler(0, event)} />
<input value={notes[1]} onChange={event => changeHandler(1, event)} />
<input value={notes[2]} onChange={event => changeHandler(2, event)} />
{getSum(notes)}
</div>;
}
On peut faire en sorte que les inputs soient générés dans une boucle :
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
const result = notes.map((note, index) => {
return <input
key={index}
value={note}
onChange={event => changeHandler(index, event)}
/>;
});
return <div>
{result}
{getSum(notes)}
</div>;
}
Le tableau suivant est donné :
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Affichez la moyenne arithmétique des éléments de ce tableau. Dans une boucle, créez des inputs pour modifier les éléments.