⊗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çeЎзбекOʻzbekTiếng Việt
Биз сайттин иштөөсү, аналитика жана персонализация үчүн cookie файлдарын колдонобуз. Маалыматтарды иштетүү Маалыматты коргоо саясаты боюнча жүргүзүлөт.
баарын кабыл алуу ыңгайлаштыруу четке кагуу