⊗jsrtPmFmsAIB 70 of 112 menu

React'ta Input'ları Diziye Bağlama

notes state'inde bir dizi olduğunu varsayalım:

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

Ayrıca, dizinin elemanlarının toplamını bulan bir yardımcı fonksiyonumuz olduğunu varsayalım:

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

State'teki dizimizin elemanlarının toplamını bulup ekrana yazdıralım, bunun için yardımcı fonksiyonumuzu kullanarak:

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

Şimdi üç tane input yapalım ve her bir input'un value değerine dizinin elemanlarından birini yazalım:

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

Şimdi input'larımıza onChange olayı ekleyelim. Bu arada, ortak bir olay işleyici fonksiyon yapalım:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // ortak olay işleyici fonksiyon } 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>; }

Gördüğünüz gibi, changeHandler fonksiyonu ilk parametre olarak, ilgili input'un düzenlediği dizi elemanının numarasını alıyor.

Bu numaraya göre, dizinin ilgili elemanını input'un içeriği ile değiştirebiliriz.

Bunu yapalım:

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

Artık herhangi bir input'u düzenleyebiliriz, bu sayede dizi reaktif bir şekilde değişecek ve buna bağlı olarak elemanlarının toplamı yeniden hesaplanacak.

Tüm kodumuzu bir araya getirelim:

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

Input'ların bir döngü içinde oluşturulmasını sağlayabiliriz:

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

Aşağıdaki dizi verilmiştir:

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

Bu dizinin elemanlarının aritmetik ortalamasını ekrana yazdırın. Elemanları düzenlemek için bir döngü içinde input'lar yapın.

Türkçe
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenЎзбекOʻzbekTiếng Việt
Web sitesinin çalışması, analiz ve kişiselleştirme için çerezleri kullanıyoruz. Veri işleme, Gizlilik Politikası'na uygun olarak gerçekleşir.
tümünü kabul et özelleştir reddet