⊗jsrtPmFmsAIB 70 of 112 menu

Syötteen sidonta taulukkoon Reactissa

Olkoon tilassa notes tallennettuna taulukko:

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

Olkoon meillä myös apufunktio, joka laskee taulukon elementtien summan:

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

Etsitään ja tulostetaan tilasta otetun taulukkomme elementtien summa käyttämällä tätä apufunktiota:

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

Tehdään nyt kolme syötekenttää ja kirjoitetaan value kuhunkin syötekenttään yksi taulukon elementeistä:

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

Lisätään nyt syötekenttiimme onChange tapahtumankäsittelijä. Tehdään samalla yksi yhteinen funktio-tapahtumankäsittelijä tälle tapahtumalle:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // yhteinen funktio-tapahtumankäsittelijä } 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>; }

Kuten näette, funktio changeHandler ottaa ensimmäisenä parametrina taulukon elementin indeksin, jota tietty syötekenttä muokkaa.

Tämän indeksin perusteella voimme korvata taulukon elementin syötekentän sisällöllä.

Tehdään tämä:

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

Nyt mitä tahansa syötekenttää voi muokata, jolloin taulukko muuttuu reaktiivisesti ja vastaavasti sen elementtien summa lasketaan uudelleen.

Kootaan kaikki koodimme yhteen:

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

Voit tehdä niin, että syötekentät muodostetaan silmukassa:

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

Annettu seuraava taulukko:

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

Tulosta ruudulle tämän taulukon elementtien keskiarvo. Tee silmukassa syötekentät elementtien muokkaamista varten.

Suomi
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Käytämme evästeitä verkkosivuston toiminnalle, analytiikalle ja personoinnille. Tietojen käsittely tapahtuu Tietosuojakäytännön mukaisesti.
hyväksy kaikki mukauta hylkää