- React nima?
- Reactni asosiy xususiyatlarini nimalar?
- Virtual DOM nima va u qanday ishlaydi?
- JSX nima?
- React Fragmentlari nima?
React - komponentalar asosida deklarativ(declarative) foydalanuvchi interfeysi (UI)ni yaratish uchun bepul va ochiq manbali Javascript kutubxonasi. React bir sahifali ilovalar(single-page applications, SPA) va mobil ilovalar yaratishi bilan mashhur. Reactning asosiy maqsadi keng qamrovli (extensive), tezkor(fast), deklarativ(declarative), moslashuvchan(flexible) va sodda(simple) ilovalar yaratishda yordam berisgdir. ReactJs 2011 yilda Facebook-da ishlaydigan dasturiy ta'minot muhandisi Jordane Walke tomonidan chiqarilgan. Kutubxona birinchi marta 2013 yil may oyida ochiq manbali kutubxona sifatida ommaga taqdim etilgan va hozirda veb-ishlab chiqish uchun eng ko'p ishlatiladigan frontend kutubxonalaridan biri hisoblanadi.
Reactning asosiy xususiyatlari quyidagilardir
- JSX - JavaScript Syntax Extension
- Virtual Document Object Model (VDOM)
- Bir tomonlama malumotlarni uzatish(One-way Data Binding)
- Server-side rendering ni qo'llab quvatlaydi
- Qayta foydalansa bo'ladigan va kompozitsiya qilinadigan UI componentalardan foydalaniladi
- Oddiylik
- Conditional Statements
DOM bu "Document Object Modal" atamasi bo'lib, ma'lumotlarni daraxt strukturasida saqlashning bir turi hisoblanadi. U ilova interfeysini ifodalaydi. Virtual DOM (VDOM) - bu dasturlash tushunchasi bo'lib, u erda foydalanuvchi interfeysining "virtual" ko'rinishi xotirada saqlanadi va Real DOM bilan sinxronlashtiriladi. Bu shuni anglatadiki, bitta element brauzer DOMida(Real DOM) yaratilganda, u Virtual DOMda ob'ekt sifatida yaratiladi. Virtual DOM - bu xotiradagi Real DOMni ifodalovchi ob'ekt.
React qaysi tugun o‘zgarganligini tekshirish uchun yangi Virtual DOM ob'ektini oldingi Virtual DOM ob'ekti bilan solishtirish uchun Diffing Algorithm algoritmidan foydalanadi va keyin Real DOMda o‘zgartirilgan qismlarni o'zgartirish orqali ilovada bitta qism o'zgartirilganda butun ilovani yangilash va sahifani qaytadan yuklashdan ancha tezroq ishlaydi.
JSX - bu JavaScript-ning sintaksisi kengaytmasi. JavaScript XML qisqartmasi JSX deb ataladi. U React bilan foydalanuvchi interfeysi qanday ko'rinishini tasvirlash uchun ishlatiladi. JSX bizga HTMLni to'g'ridan-to'g'ri Reactda (JavaScript kodi ichida) yozish imkonini beradi. React-da JSX-dan foydalanib shablon yaratish oson, lekin bu oddiy shablon tili emas, balki JavaScriptni to'liq qo'llab-quvvatlaydi. Bu oddiy JavaScript-ga qaraganda tezroq, chunki u oddiy JavaScript-ga kompilyatsiya qilishda optimallashtirishni amalga oshiradi. Kompilyatsiyadan so'ng JSX ifodalari odatiy JavaScript funksiyalariga aylanadi. JSX HTML atributlarini nomlash uchun camelcase notatsiyasidan foydalanadi.
function App() {
return(
<div>
<h1 className="title">{'Sahifamizga xush kelibsiz!'}</h1>
</div>
)
}
React Fragment
- komponenti bir nechta elementlarni boshqa konteyner elementiga o'ramasdan, bir nechta elementlarni o'rash yoki guruhlash va bitta o'rnda ko'rsatish imkonini beradi. React Componentalar bizga elementlarni yoki componentalarni bitta ota elamentga yoki ota componentaga o'rab qaytarishimizni talab qiladi va shu sababli ham biz ko'p holatlarda React Fragmentga yoki container element hisoblangan divni ishlatishimizga to'g'ri keladi. React Fragment ni<Fragment>...</Fragment>(<React.Fragment>...</React.Fragment>)
shu yoki<>...</>
bu ko'rinishda ishlatishimiz mumkin. Bo'sh JSX tegi <></> ko'p hollarda Fragment ning qisqartmasi hisoblanadi.
Nima uchun Fragmentlar divlaridan yaxshiroq?
- DOM hajmini oshiradi: DOM o'lchamlari sahifangizda juda ko'p DOM tugunlari yoki HTML teglari mavjud bo'lganda yoki bu tugunlar juda chuqur joylashtirilganda kattalashadi. Natijada, foydalanuvchi brauzeri veb-saytingizni qayta ishlash uchun qo'shimcha quvvat sarflaydi, natijada sahifani yuklash vaqti sekinlashadi va sahifa tezligi past bo'ladi.
- Div-dan foydalanish qo'shimcha tugunlarni yaratadi, bu esa xotiradan yuqori foydalanishga olib keladi.
- Katta o'lchamli DOM'lar xotiradan foydalanishning oshishiga, stylelarni qayta ishlashining kechikishiga va saytni qayta yuklash sekinlashishiga olib keladi.
- Eski qurilmalarda bu HTML-ni chalkashtirib yuborishi va unumdorlik bilan bog‘liq muammolarga olib kelishi mumkin.
- Qo'shimcha tugunlarning kelib chiqishi debugging(nosozliklarni tuzatish) va tracing(kuzatish)ni yanada qiyinlashadi, chunki komponent daraxti chuqurroq joylashadi.
- Flexbox va CSS Grid kabi ba'zi CSS mexanizmlari maxsus ota-ona munosabatlariga ega va o'rtada divlarni qo'shish kerakli tartibni saqlashni qiyinlashtiradi.
Foydalanishi
- Bir nechta elementlarni qaytarishda
function Table() {
return (
<>
<TableTitle />
<TableBody />
</>
);
}
- O'zgaruvchiga bir nechta elementlarni belgilashda
function Close() {
const buttons = (
<>
<OKButton />
<CancelButton />
</>
);
return (
<Alert buttons={buttons}>
Ushbu sahifani tark etmoqchimisiz?
</Alert>
);
}
- Elementlarni matn bilan guruhlashda
function DateRangePicker({ start, end }) {
return (
<>
<DatePicker date={start} />
dan
<DatePicker date={end} />
gacha
</>
);
}
- Fragmentlar ro'yxatini ko'rsatishda
Bu erda biz <></> sintaksisidan foydalana olmaymiz uning o'rniga Fragmentni aniq yozishimiz kerak bo'ladi. Bu <></> foydalana olmasligimizni sababi biz unga attribute(xususiyat) yoki key bera olmasligimizda.
function Blog() {
return posts.map(post =>
<Fragment key={post.id}>
<PostTitle title={post.title} />
<PostBody body={post.body} />
</Fragment>
);
}
Kamchiliklar yoki xatolarni topsangiz pull so'rovini yuborishingizni so'raymiz. Taklif va mulohazalaringiz bo'lsa Bizga murojat qiling