АКЦЫЯ: бясплатныя месячныя курсы па стварэнні сайтаў
на выбар: вёрстка, JavaScript, PHP, Python або фрэймворкі. Сёння апошні дзень для запісу! Націскай!
⊗jsrtPmDtOAOp 76 of 112 menu

Рэактыўныя аперацыі над масівамі аб'ектаў у React

Давайце цяпер навучымся рабіць рэактыўныя аперацыі над масівамі аб'ектаў. У гэтым выпадку мы павінны перадаць у функцыю id элемента масіва, з якім мы збіраемся нешта рабіць:

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

Для таго, каб нешта зрабіць з элементам, мы спачатку павінны знайсці яго, перабраўшы ўвесь масіў цыклам:

function App() { ... function doSmth(id) { setNotes(notes.map(note => { if (note.id === id) { // нешта робім з элементам } return note; })); } }

Давайце для прыкладу зменім тэксты знойдзенага аб'екта:

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

У канцы кожнай li зрабіце кнопку, па націсканні на якую гэтая li будзе выдаляцца са спісу.

Даны тры інпуты. У канцы кожнай li зрабіце кнопку, па націсканні на якую даныя аб'екта гэтай li будуць трапляць у адпаведныя інпуты.

Мадыфікуйце папярэднюю задачу так, каб побач з інпутамі была кнопка, па націсканні на якую даныя інпутаў будуць трапляць у адпаведную li.

byenru