⊗jsrtPmFmsAIB 70 of 112 menu

Sisendite seostamine massiiviga Reactis

Oletame, et olekus notes hoitakse massiivi:

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

Oletame, et meil on ka abifunktsioon, mis leiab massiivi elementide summa:

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

Leiame ja kuvame meie oleku massiivi elementide summa, kasutades selleks meie abifunktsiooni:

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

Teeme nüüd kolm sisendit ja paneme value igas sisendisse ühe massiivi elemendi:

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

Lisame nüüd meie sisenditele sündmuse onChange. Teeme selleks ühe ühise käitlejafunktsiooni selle sündmuse jaoks:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // ühine käitlejafunktsioon } 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>; }

Nagu näete, võtab funktsioon changeHandler esimese parameetrina massiivi elemendi numbri, mida antud sisend redigeerib.

Selle numbri alusel saame massiivi elemendi asendada sisendi sisuga.

Teeme selle:

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

Nüüd on võimalik redigeerida mis tahes sisendit, samal ajal reageerivalt muutub massiiv ja vastavalt sellele arvutatakse ümber selle elementide summa.

Paneme kogu meie kood kokku:

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

Võib teha nii, et sisendeid moodustataks tsüklis:

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

Antud on järgmine massiiv:

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

Kuva ekraanile selle massiivi elementide aritmeetiline keskmine. Tee tsüklis sisendid elementide redigeerimiseks.

Eesti
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Me kasutame saidi toimimiseks, analüüsi ja personaliseerimiseks küpsiseid. Andmete töötlemine toimub vastavalt Privaatsuspoliitikale.
nõustu kõigega häälesta keeldu