Lidhja e input-eve me një array në React
Le të supozojmë se në state notes ruhet një array:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Le të supozojmë gjithashtu se kemi një funksion ndihmës, që gjen shumën e elementeve të array-it:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Le të gjejmë dhe shfaqim shumën e elementeve të array-it tonë nga state, duke përdorur funksionin tonë ndihmës:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Tani le të krijojmë tre input-e dhe në value
të çdo input-i do të vendosim një nga elementët e array-it:
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>;
}
Tani le të shtojmë event-in onChange
në input-et tona. Në të njëjtën kohë, le të krijojmë një funksion
të përbashkët për trajtimin e këtij event-i:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// funksioni i përbashkët për trajtimin e event-it
}
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>;
}
Siç e shihni, funksioni changeHandler
si parametër të parë e merr numrin e atij elementi
të array-it që ky input po redakton.
Me këtë numër ne mund të zëvendësojmë elementin e array-it me përmbajtjen e input-it.
Le ta bëjmë këtë:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Tani do të jetë e mundur të redaktohet çdo input, në të njëjtën kohë në mënyrë reaktive do të ndryshojë array-i dhe, në përputhje me rrethanat, do të rillogaritet shuma e elementeve të tij.
Le të mbledhim të gjithë kodin tonë së bashku:
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>;
}
Mund të bëhet në mënyrë që input-et të krijohen në një cikël:
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>;
}
Është dhënë array-i në vijim:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Shfaqni në ekran mesataren aritmetike të elementeve të këtij array-i. Në një cikël krijojeni input-e për redaktimin e elementeve.