⊗jsrtPmFmsAIB 70 of 112 menu

Povezivanje input polja sa nizom u React-u

Neka se u stanju notes nalazi niz:

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

Neka takođe imamo i pomoćnu funkciju koja nalazi zbir elemenata niza:

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

Hajde da nađemo i ispišemo zbir elemenata našeg niza iz stanja, koristeći za to našu pomoćnu funkciju:

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

Hajde sada da napravimo tri input polja i u value svakog inputa upišemo jedan od elemenata niza:

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

Hajde sada da dodamo događaj onChange našim input poljima. Pored toga, hajde da napravimo jednu zajedničku funkciju-rukovalac ovog događaja:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // zajednička funkcija-rukovalac } 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>; }

Kao što vidite, funkcija changeHandler prvi parametar prima broj onog elementa niza koji dato input polje menja.

Prema ovom broju možemo da zamenimo element niza sadržajem input polja.

Uradimo to:

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

Sada ćemo moći da uredimo bilo koje input polje, pri čemu će se reaktivno menjati niz i, shodno tome, ponovo izračunavati zbir njegovih elemenata.

Hajde da spojimo sav naš kod:

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

Moguće je napraviti da se input polja formiraju u petlji:

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

Dat je sledeći niz:

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

Ispišite na ekran aritmetičku sredinu elemenata ovog niza. U petlji napravite input polja za uređivanje elemenata.

Srpski
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Koristimo kolačiće za rad sajta, analitiku i personalizaciju. Obrada podataka se vrši u skladu sa Politikom privatnosti.
prihvati sve podesi odbij