React-də Inputları Massivə Bağlamaq
Tutaq ki, state-də notes massivi saxlanılır:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Tutaq ki, bizim həmçinin massivin elementlərinin cəmini tapan köməkçi funksiyamız var:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Gəlin state-dəki massivimizin elementlərinin cəmini tapaq və çap edək, bunun üçün köməkçi funksiyamızdan istifadə edək:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Gəlin indi üç input hazırlayaq və hər bir inputun value-na
massivin elementlərindən birini yazaq:
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>;
}
Gəlin indi inputlarımıza onChange hadisəsi əlavə edək.
Bununla belə, bir ümumi
funksiya-işləyici hazırlayaq:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// ümumi funksiya-işləyici
}
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üyünüz kimi, changeHandler funksiyası
ilk parametr kimi massivin hansı elementinin
dəyişdirildiyinin nömrəsini qəbul edir.
Bu nömrəyə əsasən biz massivin elementini inputun dəyəri ilə əvəz edə bilərik.
Gəlin bunu edək:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
İndi istənilən inputu dəyişdirmək olar, eyni zamanda massiv reaktiv şəkildə dəyişəcək və müvafiq olaraq onun elementlərinin cəmi yeni hesablanacaq.
Gəlin bütün kodumuzu birlikdə toplayaq:
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>;
}
Inputların dövr içərisində yaradılmasını təmin etmək olar:
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ğıdakı massiv verilmişdir:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Bu massivin elementlərinin ədədi ortasını ekranda göstərin. Dövr içərisində elementləri dəyişdirmək üçün inputlar yaradın.