⊗jsrtPmFmsAIB 70 of 112 menu

Binding von Inputs an ein Array in React

Angenommen, im State notes ist ein Array gespeichert:

function App() { const [notes, setNotes] = useState([1, 2, 3]); return <div> </div>; }

Angenommen, wir haben auch eine Hilfsfunktion, die die Summe der Array-Elemente berechnet:

function getSum(arr) { let sum = 0; for (const elem of arr) { sum += +elem; } return sum; } function App() { ... }

Lassen Sie uns die Summe der Elemente unseres Arrays aus dem State berechnen und ausgeben, indem wir unsere Hilfsfunktion verwenden:

function App() { const [notes, setNotes] = useState([1, 2, 3]); return <div> {getSum(notes)} </div>; }

Lassen Sie uns nun drei Inputs erstellen und in value jedes Inputs eines der Elemente des Arrays eintragen:

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>; }

Fügen wir nun den Inputs ein onChange-Event hinzu. Dabei erstellen wir eine gemeinsame Handler-Funktion für dieses Event:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // gemeinsame Handler-Funktion } 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>; }

Wie Sie sehen, erhält die Funktion changeHandler als ersten Parameter die Nummer des Array-Elements, das dieser Input bearbeitet.

Anhand dieser Nummer können wir das Element des Arrays durch den Inhalt des Inputs ersetzen.

Setzen wir das um:

function changeHandler(index, event) { setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]); }

Nun kann jeder Input bearbeitet werden, wodurch das Array reaktiv geändert wird und folglich die Summe seiner Elemente neu berechnet wird.

Fassen wir unseren gesamten Code zusammen:

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>; }

Man kann es so einrichten, dass die Inputs in einer Schleife erzeugt werden:

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>; }

Gegeben ist das folgende Array:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

Geben Sie den Durchschnittswert der Elemente dieses Arrays auf dem Bildschirm aus. Erstellen Sie in einer Schleife Inputs zur Bearbeitung der Elemente.

Deutsch
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Wir verwenden Cookies für den Betrieb der Website, Analyse und Personalisierung. Die Datenverarbeitung erfolgt gemäß der Datenschutzerklärung.
alle akzeptieren anpassen ablehnen