⊗jsrtPmFmsAIB 70 of 112 menu

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ň.

Türkmen
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkçeЎзбекOʻzbekTiếng Việt
Biz sahypanyň işlemegi, analitika we şahsyýetleşdirmek üçin cookie ulanýarys. Maglumatlaryň işlenişi Gizlinlik syýasaty boýunça amala aşyrylýar.
hemmesini kabul et sazlamak ret et