⊗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が リストから削除されるようにしてください。

3つの入力欄があります。各liの 末尾にボタンを作成し、クリックすると そのliのオブジェクトデータが 対応する入力欄に入力されるようにしてください。

前の課題を修正し、入力欄の横にボタンを配置してください。 このボタンをクリックすると、入力欄のデータが 対応するliに入力されるようにします。

日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικά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
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否