⊗jsrtPmFmsAIB 70 of 112 menu

Tilkobling av inputs til en array i React

La i staten notes lagres en array:

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

La oss også ha en hjelpefunksjon som finner summen av elementene i arrayen:

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

La oss finne og vise summen av elementene i vår array fra staten, ved å bruke vår hjelpefunksjon:

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

La oss nå lage tre inputs og i value hver input skrive vi ett av elementene i arrayen:

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

La oss nå legge til hendelsen onChange på våre inputs. La oss samtidig lage en felles handlerfunksjon for denne hendelsen:

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

Som du ser, tar funksjonen changeHandler første parameter som nummeret på det elementet i arrayen som denne inputen redigerer.

Ved hjelp av dette nummeret kan vi erstatte elementet i arrayen med innholdet i inputen.

La oss gjøre dette:

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

Nå vil det være mulig å redigere hvilken som helst input, samtidig som arrayen reaktivt vil endre seg og følgelig vil summen av elementene bli beregnet på nytt.

La oss samle all koden vår sammen:

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

Det er mulig å gjøre slik at inputs genereres i en loop:

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

Gitt følgende array:

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

Vis på skjermen gjennomsnittet av elementene i denne arrayen. I en loop, lag inputs for redigering av elementene.

Norsk
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi bruker informasjonskapsler for nettstedets funksjonalitet, analyse og personalisering. Behandling av data foregår i henhold til Personvernerklæringen.
godta alle tilpass avvis