Везивање инпутa за низ у React-у
Нека у стању notes буде сачуван низ:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Нека нам такође буде доступна помоћна функција која проналази суму елемената низа:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Хајде да пронађемо и прикажемо суму елемената нашег низа из стања, користећи за то нашу помоћну функцију:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Хајде сада да направимо три инпута и у value
сваког инпута уписујемо по један елемент низа:
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>;
}
Хајде сада да додамо догађај onChange
нашим инпутима. При том ћемо направити једну заједничку
функцију-обрађивач тог догађаја:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// заједничка функција-обрађивач
}
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>;
}
Као што видите, функција changeHandler
као први параметар прихвата број оног елемента
низа који дати инпут уређује.
По том броју можемо заменити елемент низа садржајем инпута.
Хајде то да урадимо:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Сада ћемо моћи да уредимо било који инпут, при чему ће се реактивно мењати низ и, одговарајуће, прерачунавати сума његових елемената.
Хајде да сакупимо цео наш код:
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>;
}
Може се урадити тако да се инпути формирају у петљи:
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>;
}
Дат је следећи низ:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Прикажите на екрану аритметичку средину елемената овог низа. У петљи направите инпуте за уређивање елемената.