Tilkobling av inputs til en array i React
La i staten notes lagres en array:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
La oss også ha en hjelpefunksjon som finner summen av elementene i arrayen:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
La oss finne og vise summen av elementene i vår array fra staten, ved å bruke vår hjelpefunksjon:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
La oss nå lage tre inputs og i value
hver input skrive vi ett av elementene i arrayen:
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>;
}
La oss nå legge til hendelsen onChange
på våre inputs. La oss samtidig lage en felles
handlerfunksjon for denne hendelsen:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// felles handlerfunksjon
}
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 ser, tar funksjonen changeHandler
første parameter som nummeret på det elementet
i arrayen som denne inputen redigerer.
Ved hjelp av dette nummeret kan vi erstatte elementet i arrayen med innholdet i inputen.
La oss gjøre dette:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Nå vil det være mulig å redigere hvilken som helst input, samtidig som arrayen reaktivt vil endre seg og følgelig vil summen av elementene bli beregnet på nytt.
La oss samle all koden vår sammen:
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 er mulig å gjøre slik at inputs genereres i en loop:
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>;
}
Gitt følgende array:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Vis på skjermen gjennomsnittet av elementene i denne arrayen. I en loop, lag inputs for redigering av elementene.