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]
Бул массивдин элементтеринин орточо арифметикалык маанисин экранга чыгарыңыз. Цикл ичинде элементтерди оңдоо үчүн киргизүүчүлөрдү жасаңыз.