Прывязка інпутаў да масіву ў 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
кожнага інпута запiшам адзін з элементаў масіву:
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]
Вывядзіце на экран сярэдняе арыфметычнае элементаў гэтага масіву. У цыкле зрабіце інпуты для рэдагавання элементаў.