Prepojenie vstupov s poľom v Reacte
Nech v stave notes je uložené pole:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Nech máme tiež pomocnú funkciu, ktorá nájde súčet prvkov poľa:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Nájdime a vypíšme súčet prvkov nášho poľa zo stavu, pričom použijeme našu pomocnú funkciu:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Urobme teraz tri vstupy a do value
každého vstupu zapíšme jeden z prvkov poľa:
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>;
}
Pridajme teraz udalosť onChange
naším vstupom. Pritom urobme jednu spoločnú
funkciu-obslužníka tejto udalosti:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// spoločná funkcia-obslužník
}
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>;
}
Ako vidíte, funkcia changeHandler
prvým parametrom prijíma číslo toho prvku
pola, ktorý daný vstup upravuje.
Podľa tohto čísla môžeme nahradiť prvok pola obsahom vstupu.
Urobme to:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Teraz bude možné upraviť ľubovoľný vstup, pričom reaktívne sa zmení pole a tým sa prepočíta súčet jeho prvkov.
Poďme zhromaždiť celý náš kód:
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>;
}
Je možné urobiť tak, aby sa vstupy tvorili v cykle:
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>;
}
Dané je nasledujúce pole:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Vypíšte na obrazovku aritmetický priemer prvkov tohto poľa. V cykle urobte vstupy pre úpravu prvkov.