Įvesties laukų susiejimas su masyvu React
Tarkime, kad būsenoje notes saugomas masyvas:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Tarkime, kad turime ir pagalbinę funkciją, kuri randą masyvo elementų sumą:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Suraskime ir išveskime mūsų būsenos masyvo elementų sumą, panaudoję mūsų pagalbinę funkciją:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Dabar sukurkime tris įvesties laukus ir į value
kiekvieno įvesties lauko įrašykime vieną iš masyvo elementų:
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>;
}
Dabar pridėkime onChange įvykį
mūsų įvesties laukams. Tuo pačiu padarykime vieną bendrą
funkciją-apdorotoją šio įvykio:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// bendra funkcija-apdorotoja
}
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>;
}
Kaip matote, funkcija changeHandler
pirmu parametru priima to masyvo elemento numerį,
kurį redaguoja šis įvesties laukas.
Pagal šį numerį mes galime pakeisti masyvo elementą į įvesties lauko turinį.
Padarykime tai:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Dabar galėsime paredaguoti bet kurį įvesties lauką, tuo pačiu reaktyviai pasikeis masyvas ir, atitinkamai, persiskaiciuos jo elementų suma.
Sukraukime visą mūsų kodą kartu:
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>;
}
Galima padaryti taip, kad įvesties laukai formuotųsi cikle:
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>;
}
Duotas toks masyvas:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Parodykite ekrane aritmetinį šio masyvo elementų vidurkį. Cikle padarykite įvesties laukus elementų redagavimui.