Collegamento di input a un array in React
Supponiamo che nello stato notes sia memorizzato un array:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Supponiamo inoltre di avere una funzione helper, che calcola la somma degli elementi dell'array:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Calcoliamo e visualizziamo la somma degli elementi del nostro array nello stato, utilizzando la nostra funzione helper:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Creiamo ora tre input e in value
di ogni input inseriamo uno degli elementi dell'array:
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>;
}
Aggiungiamo ora l'evento onChange
ai nostri input. Creiamo un'unica funzione
gestore comune per questo evento:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// funzione gestore comune
}
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>;
}
Come puoi vedere, la funzione changeHandler
accetta come primo parametro il numero dell'elemento
dell'array che questo input modifica.
Tramite questo numero possiamo sostituire l'elemento dell'array con il contenuto dell'input.
Implementiamolo:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Ora sarà possibile modificare qualsiasi input, e l'array cambierà in modo reattivo e, di conseguenza, verrà ricalcolata la somma dei suoi elementi.
Riuniamo tutto il codice:
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>;
}
Si può fare in modo che gli input vengano generati in un ciclo:
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>;
}
È dato il seguente array:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Visualizza la media aritmetica degli elementi di questo array. In un ciclo crea degli input per modificare gli elementi.