⊗jsrtPmFmsAIB 70 of 112 menu

Įvesties laukų susiejimas su masyvu React

Tarkime, kad būsenoje notes saugomas masyvas:

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

Tarkime, kad turime ir pagalbinę funkciją, kuri randą masyvo elementų sumą:

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

Suraskime ir išveskime mūsų būsenos masyvo elementų sumą, panaudoję mūsų pagalbinę funkciją:

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

Dabar sukurkime tris įvesties laukus ir į value kiekvieno įvesties lauko įrašykime vieną iš masyvo elementų:

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

Dabar pridėkime onChange įvykį mūsų įvesties laukams. Tuo pačiu padarykime vieną bendrą funkciją-apdorotoją šio įvykio:

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

Kaip matote, funkcija changeHandler pirmu parametru priima to masyvo elemento numerį, kurį redaguoja šis įvesties laukas.

Pagal šį numerį mes galime pakeisti masyvo elementą į įvesties lauko turinį.

Padarykime tai:

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

Dabar galėsime paredaguoti bet kurį įvesties lauką, tuo pačiu reaktyviai pasikeis masyvas ir, atitinkamai, persiskaiciuos jo elementų suma.

Sukraukime visą mūsų kodą kartu:

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

Galima padaryti taip, kad įvesties laukai formuotųsi cikle:

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

Duotas toks masyvas:

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

Parodykite ekrane aritmetinį šio masyvo elementų vidurkį. Cikle padarykite įvesties laukus elementų redagavimui.

Lietuvių
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Mes naudojame slapukus svetainės veikimui, analizei ir personalizavimui. Duomenų apdorojimas vyksta pagal Privatumo politiką.
priimti visus nustatyti atšaukti