Povezovanje vnosnih polj z matriko v Reactu
Naj v stanju notes hrani matrika:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Naj imamo tudi pomožno funkcijo, ki izračuna vsoto elementov matrike:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Poiščimo in izpišimo vsoto elementov naše matrike iz stanja, pri čemer uporabimo našo pomožno funkcijo:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Naredimo zdaj tri vnosna polja in v value
vsakega vnosnega polja zapišimo en element matrike:
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>;
}
Dodajmo zdaj dogodek onChange
našim vnosnim poljem. Pri tem naredimo eno skupno
funkcijo-obravnavalko tega dogodka:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// skupna funkcija-obravnavalka
}
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>;
}
Kot vidite, funkcija changeHandler
kot prvi parameter sprejme številko elementa
matrike, ki ga ureja to vnosno polje.
S to številko lahko zamenjamo element matrike z vsebino vnosnega polja.
Naredimo to:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Zdaj lahko uredimo katero koli vnosno polje, pri tem pa se bo reaktivno spremenila matrika in s tem preračunala vsota njenih elementov.
Zberimo celotno kodo skupaj:
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>;
}
Lahko naredimo tako, da se vnosna polja oblikujejo v zanki:
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>;
}
Podana je naslednja matrika:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Prikažite na zaslonu aritmetično sredino elementov te matrike. V zanki naredite vnosna polja za urejanje elementov.