⊗jsrtPmFmsAIB 70 of 112 menu

Prepojenie vstupov s poľom v Reacte

Nech v stave notes je uložené pole:

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

Nech máme tiež pomocnú funkciu, ktorá nájde súčet prvkov poľa:

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

Nájdime a vypíšme súčet prvkov nášho poľa zo stavu, pričom použijeme našu pomocnú funkciu:

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

Urobme teraz tri vstupy a do value každého vstupu zapíšme jeden z prvkov poľa:

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

Pridajme teraz udalosť onChange naším vstupom. Pritom urobme jednu spoločnú funkciu-obslužníka tejto udalosti:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // spoločná funkcia-obslužník } 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>; }

Ako vidíte, funkcia changeHandler prvým parametrom prijíma číslo toho prvku pola, ktorý daný vstup upravuje.

Podľa tohto čísla môžeme nahradiť prvok pola obsahom vstupu.

Urobme to:

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

Teraz bude možné upraviť ľubovoľný vstup, pričom reaktívne sa zmení pole a tým sa prepočíta súčet jeho prvkov.

Poďme zhromaždiť celý náš kód:

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

Je možné urobiť tak, aby sa vstupy tvorili v cykle:

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

Dané je nasledujúce pole:

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

Vypíšte na obrazovku aritmetický priemer prvkov tohto poľa. V cykle urobte vstupy pre úpravu prvkov.

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
Používame cookies na fungovanie stránky, analýzu a personalizáciu. Spracúvanie údajov prebieha v súlade s Politikou ochrany osobných údajov.
prijať všetky nastaviť odmietnuť