⊗jsrtPmFmsAIB 70 of 112 menu

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.

Français
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Nous utilisons des cookies pour le fonctionnement du site, l'analyse et la personnalisation. Le traitement des données est effectué conformément à la Politique de confidentialité.
accepter tout personnaliser refuser