⊗jsrtPmCoTOS 96 of 112 menu

Reactda bitta haqiqat manbai

React-ilova uchun har qanday o'zgaruvchan ma'lumotlar bitta haqiqat manbaiga ega bo'lishi kerak. Bu so'zlar bilan shuni anglatadiki, agar sizda ikkita holat bo'lsa va bitta holat ikkinchisi orqali hisoblanishi mumkin bo'lsa - demak bitta holatlar ortiqcha va uni olib tashlash kerak.

Buni misol orqali muhokama qilaylik. Faraz qilaylik, sizda ikkita input maydon bor: birinchisiga harorat Farengeyt darajasida kiritiladi, ikkinchisiga esa - Selsiy darajasida. Shu bilan birga, biz ikkala input ham sinxronlashtirilgan bo'lishini xohlaymiz: haroratni bir inputga kiritishda u mos ravishda ikkinchisida ham o'zgarishi kerak.

Noto'g'ri yondashuv ikkita holat kiritish bo'ladi: biri Farengeyt bo'yicha harorat uchun, ikkinchisi esa - Selsiy bo'yicha. Nega noto'g'ri: chunki bitta harorat ikkinchisidan hisoblanadi, shuning uchun ma'lumotlarni saqlash joyi sifatida bitta holat bo'lishi kerak.

Tasvirlangan vazifani amalga oshirish kodini yozing.

Ma'lum bir dasturchi massiv elementlari yig'indisini chiqaradigan kod yozgan:

function getSum(arr) { let res = 0; for (let elem of arr) { res += +elem; } return res; } function Calculator() { const [value, setValue] = useState(''); const [nums, setNums] = useState([1, 2, 3]); const [sum, setSum] = useState(6); // massiv elementlari yig'indisi function handleChange(event) { setValue(event.target.value); } function handleBlur(event) { setNums([...nums, event.target.value]); // massivga element qo'shamiz setSum(getSum([...nums, event.target.value])); // yig'indini qayta hisoblaymiz } return <div> <p>{sum}</p> <input value={value} onChange={handleChange} onBlur={handleBlur} /> </div>; }

Ushbu kodda nima noto'g'ri? Uni tuzating.

Ma'lum bir dasturchi massiv elementlarini tahrirlash uchun kod yozgan:

function App() { const [notes, setNotes] = useState([1, 2, 3, 4, 5]); const [editNum, setEditNum] = useState(null); const [value, setValue] = useState(''); const result = notes.map((note, index) => { return <p key={index} onClick={() => startEdit(index)}> {note} </p>; }); function startEdit(index) { setEditNum(index); setValue(notes[index]); // tahrirlanayotgan element matnini alohida holatga yozamiz } function changeItem(event) { setValue(event.target.value); setNotes([...notes.slice(0, editNum), event.target.value,...notes.slice(editNum + 1)]); } return <div> {result} <input value={value} onChange={changeItem} /> </div>; }

Ushbu kodda nima noto'g'ri? Uni tuzating.

Oʻzbek
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекTiếng Việt
Biz sayt ishlashi, tahlil qilish va shaxsiylashtirish uchun cookie-fayllardan foydalanamiz. Ma'lumotlarni qayta ishlash Maxfiylik siyosatiga muvofiq amalga oshiriladi.
hammasini qabul qilish sozlash rad etish