⊗jsrtPmFmsAIB 70 of 112 menu

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]

Бұл массив элементтерінің орташа арифметикалық мәнін экранға шығарыңыз. Циклде элементтерді өңдеу үшін енгізулер жасаңыз.

Қазақ
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართული한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Біз сайттың жұмысы, аналитика және персонализация үшін cookie файлдарын қолданамыз. Деректерді өңдеу Құпиялылық саясаты бойынша жүреді.
барлығын қабылдау баптау қабылдамау