⊗jsrtPmFmsAIB 70 of 112 menu

Reactda Inputlarni Massivga Bog‘lash

Holatda notes massivi saqlansin:

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

Shuningdek, massiv elementlari yig‘indisini topadigan yordamchi funktsiyamiz bor:

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

Keling, holatdagi massivimiz elementlari yig‘indisini topamiz va chiqaramiz, buning uchun yordamchi funktsiyamizdan foydalanamiz:

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

Keling, endi uchta input yaratamiz va har bir inputning value qismiga massivning elementlaridan birini yozamiz:

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

Keling, endi inputlarimizga onChange hodisasini qo‘shamiz. Bunda bitta umumiy ishlovchi funktsiya yaratamiz:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // umumiy ishlovchi funktsiya } 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>; }

Ko‘rib turganingizdek, changeHandler funktsiyasi birinchi parametr sifatida massivning qaysi elementini tahrirlayotganini bildiruvchi raqamni qabul qiladi.

Ushbu raqam yordamida massiv elementini input mazmuni bilan almashtirishimiz mumkin.

Buni amalga oshiramiz:

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

Endi istalgan inputni tahrirlash mumkin, shu bilan birga massiv reaktiv o‘zgaradi va uning elementlari yig‘indisi qayta hisoblanadi.

Keling, barcha kodimizni bir joyga to‘plab chiqamiz:

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

Inputlarni tsiklda yaratish mumkin:

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

Quyidagi massiv berilgan:

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

Ushbu massiv elementlarining o‘rta arifmetigini ekranda chiqaring. Tsiklda elementlarni tahrirlash uchun inputlar yarating.

Oʻzbek
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекTiếng Việt
Biz sayt ishlashi, tahlil qilish va shaxsiylashtirish uchun cookie-fayllardan foydalanamiz. Ma'lumotlarni qayta ishlash Maxfiylik siyosatiga muvofiq amalga oshiriladi.
hammasini qabul qilish sozlash rad etish