Tilbinding af inputs til en array i React
Lad der i staten notes være gemt en array:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Lad os også have en hjælpefunktion, der finder summen af arrayens elementer:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Lad os finde og udskrive summen af elementerne i vores array fra staten ved at bruge vores hjælpefunktion:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Lad os nu lave tre inputs og i value
af hver input skrive et af arrayens elementer:
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>;
}
Lad os nu tilføje en onChange hændelse
til vores inputs. Lad os lave en fælles
håndteringsfunktion for denne hændelse:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// fælles håndteringsfunktion
}
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>;
}
Som du kan se, tager funktionen changeHandler
som første parameter nummeret på det array-element,
som denne input redigerer.
Ved hjælp af dette nummer kan vi erstatte elementet i arrayet med indholdet af inputfeltet.
Lad os gøre dette:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Nu vil det være muligt at redigere ethvert inputfelt, hvorefter arrayet reaktivt vil ændre sig og følgelig vil summen af dets elementer blive genberegnet.
Lad os samle al vores kode:
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>;
}
Det kan gøres sådan, at inputfelterne dannes i en løkke:
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>;
}
Følgende array er givet:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Vis gennemsnittet af elementerne i denne array på skærmen. Lav inputfelter til redigering af elementerne i en løkke.