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.