⊗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
ვებსაიტის მუშაობის, ანალიტიკისა და პერსონალიზაციისთვის ვიყენებთ ქუქი-ფაილებს. მონაცემთა დამუშავება ხდება Კონფიდენციალურობის პოლიტიკის შესაბამისად.
ყველას მიღება პარამეტრები უარყოფა