⊗jsrtPmFmsAIB 70 of 112 menu

Прывязка інпутаў да масіву ў React

Хай у стэйце notes захоўваецца масіў:

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

Хай у нас таксама ёсць дапаможная функцыя, якая знаходзіць суму элементаў масіву:

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

Давайце знойдзем і вывядзем суму элементаў нашага масіву з стэйта, выкарыстаўшы для гэтага нашу дапаможную функцыю:

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

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

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

Давайце цяпер дададзім падзею onChange нашым інпутам. Пры гэтым зробім адну агульную функцыю-апрацоўшчык гэтай падзеі:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // агульная функцыя-апрацоўшчык } 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>; }

Як вы бачыце, функцыя changeHandler першым параметрам прымае нумэр таго элемента масіву, які рэдагуе дадзены інпут.

Па гэтым нумары мы можам замяніць элемент масіву на змест інпута.

Зробім гэта:

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

Цяпер можна будзе парэдагаваць любы інпут, пры гэтым рэактыўна будзе мяняцца масіў і, адпаведна, пералічвацца сума яго элементаў.

Давайце саберем увесь наш код разам:

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

Можна зрабіць так, каб інпуты фарміраваліся ў цыкле:

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

Дадзены наступны масіў:

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

Вывядзіце на экран сярэдняе арыфметычнае элементаў гэтага масіву. У цыкле зрабіце інпуты для рэдагавання элементаў.

Беларуская
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
Мы выкарыстоўваем cookie для працы сайта, аналітыкі і персаналізацыі. Апрацоўка дадзеных адбываецца згодна Палітыкай канфідэнцыяльнасці.
прыняць усе наладзіць адхіліць