React-da girişleri massiwe baglamak
notes ýagdaýynda massiw saklansyn:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
</div>;
}
Bizde şeýle-de massiw elementleriniň jemyny tapýan kömekçi funksiýa bolsun:
function getSum(arr) {
let sum = 0;
for (const elem of arr) {
sum += +elem;
}
return sum;
}
function App() {
...
}
Bizde ýagdaýdaky massiwimiziň elementleriniň jýmyny kömekçi funksiýamyzy ulanýp, tapalyň we çykaryň:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
return <div>
{getSum(notes)}
</div>;
}
Indi üç sany giriş ýasalyň we her bir girişiň
value-syna massiwden bir elementi ýazalyň:
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>;
}
Indi girişlerimize onChange wakasyny
goşalyň. Şol bir wagtyň özünde bir ýörite
gaýtaryjy funksiýa ýasalyň:
function App() {
const [notes, setNotes] = useState([1, 2, 3]);
function changeHandler(index, event) {
// ýörite gaýtaryjy funksiýa
}
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>;
}
Görşüňiz ýaly, changeHandler funksiýasy
birinji parametr hökmünde massiw elementiniň
şol giriş tarapyndan redaktirlenýän nomerini
gabul edýär.
Bu nomer bilen biz massiw elementini girişiň mazmuny bilen çalyşyp bilýäris.
Muny amala aşyralyň:
function changeHandler(index, event) {
setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]);
}
Indi islendik girişi redaktirlemek mümkin, şol bir wagtyň özünde massiw reaksiýaly üýtgeýär we degişlilikde onuň elementleriniň jemi gaýtadan hasaplanar.
Kodymyzyň hemmesini bilelikde ýygnalyň:
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>;
}
Girişleri aýlawda döretmek mümkin:
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>;
}
Şu massiw berlen:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
Bu massiw elementleriniň ortaça arifmetikasyny ekrana çykaryň. Elementleri redaktirlemek üçin girişleri aýlawda ýasaň.