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.