Sisendite seostamine massiiviga Reactis
Oletame, et olekus notes hoitakse massiivi:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Oletame, et meil on ka abifunktsioon, mis leiab massiivi elementide summa:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Leiame ja kuvame meie oleku massiivi elementide summa, kasutades selleks meie abifunktsiooni:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Teeme nüüd kolm sisendit ja paneme value
igas sisendisse ühe massiivi elemendi:
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>;
}
Lisame nüüd meie sisenditele sündmuse onChange.
Teeme selleks ühe ühise
käitlejafunktsiooni selle sündmuse jaoks:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// ühine käitlejafunktsioon
}
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>;
}
Nagu näete, võtab funktsioon changeHandler
esimese parameetrina massiivi elemendi numbri,
mida antud sisend redigeerib.
Selle numbri alusel saame massiivi elemendi asendada sisendi sisuga.
Teeme selle:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Nüüd on võimalik redigeerida mis tahes sisendit, samal ajal reageerivalt muutub massiiv ja vastavalt sellele arvutatakse ümber selle elementide summa.
Paneme kogu meie kood kokku:
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>;
}
Võib teha nii, et sisendeid moodustataks tsüklis:
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>;
}
Antud on järgmine massiiv:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Kuva ekraanile selle massiivi elementide aritmeetiline keskmine. Tee tsüklis sisendid elementide redigeerimiseks.