⊗jsrtPmFmsAIB 70 of 112 menu

Везивање инпут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]

Прикажите на екрану аритметичку средину елемената овог низа. У петљи направите инпуте за уређивање елемената.

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