⊗jsrtPmDtOAOp 76 of 112 menu

Reaktive operationer på arrays af objekter i React

Lad os nu lære at udføre reaktive operationer på arrays af objekter. I dette tilfælde skal vi sende til funktionen id af array-elementet, som vi har til hensigt at gøre noget med:

function App() { const [notes, setNotes] = useState(initNotes); const result = notes.map(note => { return <li key={note.id}> <span>{note.prop1}</span> <span>{note.prop2}</span> <span>{note.prop3}</span> <button onClick={() => doSmth(note.id)}> btn </button> </li>; }); return <div> <ul> {result} </ul> </div>; }

For at gøre noget med et element, skal vi først finde det ved at gennemgå hele arrayet med en løkke:

function App() { ... function doSmth(id) { setNotes(notes.map(note => { if (note.id === id) { // gør noget med elementet } return note; })); } }

Lad os som eksempel ændre teksterne for det fundne objekt:

function App() { ... function doSmth(id) { setNotes(notes.map(note => { if (note.id === id) { note.prop1 += '!'; note.prop2 += '!'; note.prop2 += '!'; return note; } return note; })); } }

I slutningen af hver li lav en knap, der ved tryk vil fjerne denne li fra listen.

Der er givet tre inputfelter. I slutningen af hver li lav en knap, der ved tryk vil indsætte data fra denne li's objekt i de tilsvarende inputfelter.

Modificer den foregående opgave sådan, at der ved siden af inputfelterne er en knap, der ved tryk vil indsætte data fra inputfelterne i den tilsvarende li.

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