Рэактыўныя аперацыі над масівамі аб'ектаў у 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
.