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]
Бу массив элементларининг ўртача арифметик қийматини экранга чиқаринг. Цикл ичида элементларни таҳрирлаш учун инпутлар яратинг.