⊗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сига массивимизнинг бир элементини ѕзайлик:

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çeOʻzbekTiếng Việt
Биз веб-сайт ишлаши, таҳлил қилиш ва персоналлаштириш учун кукидан фойдаланамиз. Маълумотларни қайта ишлаш Махфийлик сиёсатига мувофиқ амалга оширилади.
ҳаммасини қабул қилиш мослаштириш рад этиш