⊗jsrtPmFmsAIB 70 of 112 menu

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.

Slovenščina
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Za delovanje spletnega mesta, analitiko in personalizacijo uporabljamo piškotke. Obdelava podatkov poteka v skladu s Politiko zasebnosti.
sprejmi vse nastavi zavrni