en
Feedback
Jasur - IT Blog

Jasur - IT Blog

Open in Telegram

- @jasurkhaitov Bilganlarim va foydali bo'lishi mumkin bo'lgan ma'lumotlarini ulashib boraman. - github.com/jasurkhaitov - jasurkhaitov.uz

Show more
The country is not specifiedTechnologies & Applications59 258
96
Subscribers
No data24 hours
-17 days
-330 days
Posts Archive
πŸ—‚ Electron.js yordamida Gemini API (2.5 flash) bilan ishlaydigan AI overlay yasab ko'rdim. Umuman olganda natija yomon emas,
+4
πŸ—‚ Electron.js yordamida Gemini API (2.5 flash) bilan ishlaydigan AI overlay yasab ko'rdim. Umuman olganda natija yomon emas, β€œshare entire screen” rejimida overlay koβ€˜rinmaydi.
setContentProtection(true)
Bu kodni asosiy vazifasi Windows'ning SetWindowDisplayAffinity API'sini chaqiradi va oynani har qanday capture pipeline'dan chiqarib tashlaydi. Cursor harakatlarini yashirish uchun keyboard shortcut’dan foydalandim. github.com/jasurkhaitov/ai-overlay P.s. Bekorchilkdan buyam bir eksperiment @jasurkh_dev

πŸ—‚ Electron.js yordamida Gemini API (2.5 flash) bilan ishlaydigan AI overlay yasab ko'rdim. Umuman olganda natija yomon emas,
+1
πŸ—‚ Electron.js yordamida Gemini API (2.5 flash) bilan ishlaydigan AI overlay yasab ko'rdim. Umuman olganda natija yomon emas, β€œshare entire screen” rejimida overlay koβ€˜rinmaydi.
setContentProtection(true)
Bu kodni asosiy vazifasi Windows'ning SetWindowDisplayAffinity API'sini chaqiradi va oynani har qanday capture pipeline'dan chiqarib tashlaydi. Cursor harakatlarini yashirish uchun keyboard shortcut’dan foydalanildi github.com/jasurkhaitov/ai-overlay πŸ’  @jasurkh_dev

πŸ—‚ Assignment vs Mutation ~ const # Eslatma * primitive - qiymatning oβ€˜zi saqlanadi * reference - qiymat emas, xotiradagi man
πŸ—‚ Assignment vs Mutation ~ const
# Eslatma * primitive - qiymatning oβ€˜zi saqlanadi * reference - qiymat emas, xotiradagi manzil (reference) saqlanadi
JavaScript’da qiymatni oβ€˜zgartirishning ikki xil yoβ€˜li bor * assignment - o'zgaruvchiga qayta qiymat berish * mutation - mavjud object / array ichidagi qiymatni oβ€˜zgartirish mutation faqatgina reference ma'lumot turlari uchun ishlaydi
let user = { name: "js" };

user.name = "ts";   // mutation

user = { name: "ts" };   // assignment
# 1. const / mutation in reference const - immutable degani emas, faqat assignment'ni taqiqlaydi, mutationni emas.
const user = { name: "js" };

user.name = "ts"; 
user = { name: "ts" }; // TypeError
# 2. React'da state rendering React render qilishi uchun state'larni oldingi va hozirgi holatlarini taqqoslaydi, agar o'zgarish bo'lsa render qiladi, o'zgarish bo'lmasa render qilmaydi Primitive state'larni taqqoslashda value'lar tenglashtiriladi, Non-primitive state'larda reference tenglashtiriladi. State'ni o'zgartirish uchun mutation qilish o'rniga assignment ishlatilinadi Mutation'ga misol:
const [user, setUser] = useState({ name: "Ali", age: 20 });

function updateAge() {
  user.age = 21;
  setUser(user);
}
* object mutate boβ€˜ldi * reference oβ€˜zgarmaydi * UI update boβ€˜lmaydi Assignment'ga misol:
function updateAge() {
  setUser({
    ...user,
    age: 21
  });
}
* yangi object yaratildi * reference oβ€˜zgardi * React re-render qiladi Buni tekshirish uchun object state’ga qiymati bir xil boβ€˜lgan yangi object berib ko'ramiz, natijada component yana render boβ€˜ladi * joshwcomeau.com/javascript/the-const-deception #javascript #react #mutation βœ…οΈ @jasurkh_dev

πŸ—‚ JavaScript Autoboxing JavaScript’da primitive qiymatlar (number, string, boolean) method va property'larga ega emas. Lekin .toLowerCase() yoki .length kabi method va property’larni chaqirsak, ular ishlaydi. Buning asosiy sababi - autoboxing Primitive qiymat ustida method yoki property chaqirilganda, JavaScript uni vaqtincha object’ga oβ€˜rab beradi, bunday object'lar wrapper object'lar deyiladi. null va undefined'dan tashqari, har bir primitive wrapper object'ga ega: * string - String() * number - Number() * boolean - Boolean() * bigint - BigInt() * symbol - Symbol() String qiymat uchun method chaqirib ko'raylik:
const myString = "Hello World";

console.log(myString.toUpperCase());
JavaScript ichida bu taxminan shunday ishlaydi:
const myString = "Hello World";

let temp = new String(myString);
temp.toUpperCase();
temp = null; // vaqtinchalik object olib tashlanadi
~~~~~~~~~~ Savol: Primitive qiymatlarga property qoβ€˜shsa boβ€˜ladimi? Property primitive’ning oβ€˜ziga emas, wrapper object’ga qoβ€˜shiladi. Lekin bu object vaqtinchalik boβ€˜lgani uchun, vazifasini bajargach o'chib ketadi.
const number = 5;
number.type = 'odd';

console.log(number.type); // undefined
Bu tahminan shunaqa ishlaydi:
const number = 5;

let temp = new Number(number);
temp.type = 'odd';
temp = null;

temp = new Number(number);
console.log(temp.type); // undefined 
* mantrax.io/javascript-autoboxing * dapelican.dev/js-object-wrappers #javascript #autoboxing @JasXDev

Repost from Ulugbek Samigjonov
How to get the most out of 2026 - Delete social media (Instagram, TikTok, etc.). It gave you NOTHING this year. - Choose ONE skill: drawing, marketing, coding - doesn't matter. - Learn every single day: books, articles, courses, mentors. - Apply what you learn: draw, market for your uncle, build a website. - Do it daily. No breaks. No excuses. Discipline wins. - Enjoy the results. Simple. Not easy. Print this. Read it daily.

πŸ—‚ Remote Code Execution in React Server Component React orqali serverdan β€œshell”gacha yetib borishga olib kelishi mumkin boβ€˜lgan xato React2Shell deb ataladi # Serialization / Deserialization * Serialization - React tree’ni Flight payload'ga o'tkazish * Deserialization - Flight payload'ni yana React tree'ga o'tkazish # React’da komponentlarning ikki turi bor: * Client Component * Server Component React Server Component (RSC) - bu React component boβ€˜lib, faqat serverda ishlaydi. Browser'ga hech qanaqa JS kod yuborilmaydi, hammasi server'da run bo'lib, render natijasi browser'ga jo'natilinadi. # Server oβ€˜zidagi Component'ni JavaScript kodini run qiladi va render natijasini ( React tree'ni ) Flight payload formatda serialize qilib clientga yuboradi
React Flight payload - bu React Server Components render natijasini clientga yuborish uchun serialize qilingan maxsus ma’lumot strukturasi
Browser serverdan kelgan Flight payload’ni deserialize qilib, uni React tree sifatida tiklaydi va UI’ni render qiladi. ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ Umumiy olganda Remote Code Execution'ga sabab bo'ladigan muammo deserialization’da, React2Shell holatida deserialization faqatgina client tarafda emas server tarafda ham ishlatilinadi. Deserialization bosqichida server'ga kelgan Flight payload’ni yetarli validatsiyasiz React modeliga (React Tree) aylantiradi, natijada tarkibida zarari JavaScript kod bo'lsa, kod birdaniga run bo'ladi.
const flight_payload = {
    '0': '$1',
    '1': {
        'status':'resolved_model',
        'reason':0,
        '_response':'$4',
        'value':'{"then":"$3:map","0":{"then":"$B3"},"length":1}',
        'then':'$2:then'
    },
    '2': '$@3',
    '3': [],
    '4': {
        '_prefix':'console.log(7*7+1)//',
        '_formData':{
            'get':'$3:constructor:constructor'
        },
        '_chunks':'$2:_response:_chunks',
    }
}
Code: blog.logrocket.com/react2shell-exploit Payload ichidagi 0, 1, 2, 3 va 4 string'lar model/chunk reference'lar hisoblanadi. $1 - 0 ID'li model/obyektga toβ€˜gβ€˜ridan‑toβ€˜gβ€˜ri reference beradi. $@3 - 3 ID'li model/obyektni Promise (async) sifatida reference qiladi, ya’ni keyinroq resolve qilinadi. "status": "resolved_model" - React uni element tree’dagi komponent qismi sifatida koβ€˜rishi kerakligi haqida signal beradi "then": "$2:then" - Model thenable ekanini bildiradi va resolve jarayonida 2 ID’li reference’dagi then metodi ishlatiladi. "value" - Modelning serialize qilingan ichki qiymati, React uni deserialize qilib ichki struktura sifatida qayta tiklaydi. "_response": "$4" - Ushbu modelga tegishli response chunk 4 ID orqali bogβ€˜langanini bildiradi. "_formData.get" - React deserialization vaqtida foydalanadigan FormData accessor reference’i, bu joy notoβ€˜gβ€˜ri ishlatilsa ichki API’larga yoβ€˜l ochib beradi # Hozirda bu bug fix qilinganini aytishyapti * nextjs.org/blog/CVE-2025-66478 Ko'proq o'qish uchun: * github.com/AdityaBhatt3010/React2Shell-CVE-2025-55182-The-Deserialization-Bug-That-Broke-the-Web * ox.security/blog/react2shell-going-granular-a-deep-deep-deep-technical-analysis-of-cve-2025-55182 * vercel.com/blog/our-million-dollar-hacker-challenge-for-react2shell #react #nextjs @JasXDev

Console'ga nima chiqadi ?
Anonymous voting

photo content

πŸ‘¨β€πŸ’» "1" + 1 = "11" | Type Coercion Type Coercion - bu JavaScriptda eng koβ€˜p tanqidga uchraydigan kamchiliklaridan biri. Typ
πŸ‘¨β€πŸ’» "1" + 1 = "11" | Type Coercion
Type Coercion - bu JavaScriptda eng koβ€˜p tanqidga uchraydigan kamchiliklaridan biri.
Type Coercion - bu JavaScript avtomatik ravishda bir turdagi qiymatni boshqasiga oβ€˜zgartiradigan holat String Coercion - Masalan:
console.log('5' + 2);     // '52'
console.log('5' + true);  // '5true'
Number Coercion - Masalan:
console.log('5' - 2);     // 3
console.log('5' * 2);     // 10
console.log('10' / '2');  // 5
Bu natijalarga sabab - JavaScript’da type checking yoβ€˜qligi va type coercion (tur oβ€˜zgarishi)'dir. + operatori 2 maqsadda ishlatiladi: string'larni birlashtirish (concatenation) yoki matematik amallarni bajarish uchun. Agar + operatori ishlatilayotgan joyda faqat raqamlar (number) boβ€˜lsa, JavaScript buni matematik amal deb tushunadi va oddiy qoβ€˜shish bajariladi. Ammo agar operandlardan biri string boβ€˜lsa, JavaScript buni matematik emas, matn birlashtirish (concatenation) deb tushunadi. Bu holatda, ikkala operand ham string'ga aylantirilib, ketma-ket birlashtiriladi. -, / va * operatorlari faqat matematik amallar uchun ishlatiladi. Bu operatorlar bilan ishlaganda, operandlar son (number) boβ€˜lishi kerak. Shuning uchun JavaScript bu operandlarni avtomatik ravishda number turiga type coercion orqali oβ€˜zgartiradi. Masalan:
"10" / "2"  β†’  10 / 2  β†’  5
Hozirda bunaqa narsalarni o'rganish shart emas, koβ€˜pchilik TypeScript’dan foydalanadi, strict type checking orqali bunday xatolarning oldini oladi. πŸ”— geeksforgeeks.org/javascript/what-is-type-coercion-in-javascript πŸ”— developer.mozilla.org/en-US/docs/Glossary/Type_coercion #javascript #typeCoercion βœ… @JasXDev

Console'ga nima chiqadi ?
Anonymous voting

photo content

πŸ—‚ Hot Module Replacement (HMR) Hot Module Replacement (HMR) β€” sahifani toβ€˜liq yangilamasdan turib, faqat oβ€˜zgartirilgan kod
πŸ—‚ Hot Module Replacement (HMR) Hot Module Replacement (HMR) β€” sahifani toβ€˜liq yangilamasdan turib, faqat oβ€˜zgartirilgan kod qismini yuklab beradi. Masalan, CSS faylida kichik oβ€˜zgarish kiritilganda, brauzer faqat shu oβ€˜zgarishni koβ€˜rsatadi, sahifaning qolgan qismi yangilanmaydi. HMR faqat ishlab chiqish (kod yozish, development) jarayonida ishlaydi. U deyarli har bir build vositalari (bundler'lar)'da mavjud. Vite, Webpack, etc... * HMR qanday ishlaydi ? Qachonki dastur run (ex. React / Vite, npm run dev) qilingan vaqtda, server ishga tushadi. Development server (vite, webpack) loyihadagi fayllarni doimiy kuzatib turadi. Fayl (masalan, CSS yoki JS) oβ€˜zgarsa - server buni darhol sezadi. Serverda WebSocket server ochilgan boβ€˜ladi.
WebSocket β€” bu server va mijoz oβ€˜rtasida real vaqtli, ikki tomonlama aloqa oβ€˜rnatishga imkon beradigan texnologiya.
Oβ€˜zgarish boβ€˜lsa, server WebSocket orqali brauzerga o'zgargan file haqida signal yuboradi. Brauzer WebSocket orqali serverga ulangan boβ€˜ladi (ws://localhost:5173). Signal kelgach, brauzer faqat oβ€˜zgargan faylni qayta yuklaydi. Sahifa toβ€˜liq yangilanmaydi, holat (state) saqlanadi. Umumiy jarayon:
Fayl oβ€˜zgarsa β†’ Server sezadi β†’ WebSocket orqali xabar β†’ Brauzer modulni yangilaydi β†’ Sahifa yangilanmaydi (reload bo'lmaydi).
Tekshirib ko'rish uchun vite.config.ts file da hmr ni o'chirib qo'yamiz
import { defineConfig } from 'vite'

export default defineConfig({
  server: {
    hmr: false, // HMR toβ€˜liq oβ€˜chiriladi
  },
})
Natijada o'zgarishlar avtomatik yuklanmaydi, yoki sahifa to'liq load bo'ladi. πŸ‘©β€πŸ’» webpack.js.org/concepts/hot-module-replacement #react #vite #hmr βœ… @JasXDev

βš™οΈ Angular Modules vs Standalone Components Angular'da komponentlar ikkita asosiy usul bilan ishlatiladi: * Module'lar orqali
βš™οΈ Angular Modules vs Standalone Components Angular'da komponentlar ikkita asosiy usul bilan ishlatiladi: * Module'lar orqali * Standalone component'lar orqali Angular Modules (Modullar) Modul - bu bir nechta komponent yoki servise'larni bir joyga jamlaydigan konteyner.
@NgModule({
  declarations: [MyComponent],
  exports: [MyComponent]
})
export class MyModule {}
* Har bir komponent avval modulga declarations orqali qoβ€˜shiladi. * Qo'shilgan component'dan boshqa joyda foydalanish uchun imports orqali chaqiriladi.
Agar komponent declarations'ga qoβ€˜shilgan boβ€˜lsa, uni faqat oβ€˜sha modul ichida ishlatish mumkin. Uni boshqa modul'da ishlatish uchun, export qilingan boβ€˜lishi va modul import qilingan boβ€˜lishi kerak.
Standalone Components ( Mustaqil komponentlar ) Standalone component'lar Angular 14 versiyada qo'shilgan bo'lib, standalone komponent oβ€˜zini oβ€˜zi boshqaroladi - unga modul kerak emas. Istagan boshqa komponentni React komponent'lariga oβ€˜xshab toβ€˜gβ€˜ridan-toβ€˜gβ€˜ri imports qilib ishlatsa boβ€˜ladi.
@Component({
  standalone: true,
  selector: 'app-hello',
  template: '<p>Hello!</p>',
  imports: [CommonModule]
})
export class HelloComponent {}
React:
import Card from './Card'
Angular:
imports: [CardComponent]
React component'lar ham standalone component hisoblanadi
Qulay tarafi: Tezroq ishlaydi, kod kamroq, soddaroq Kamchiligi: Katta loyihalarda boshqaruv biroz murakkab boβ€˜lishi mumkin πŸ”— medium.com/@ausaf.cs/angular-modules-vs-standalone-components-a-detailed-comparison-7b28c803cdd2 πŸ”— lynkz.com.au/blog/2024-angular-standalone-vs-modules #angular #standalone #module βœ… @JasXDev

πŸ—‚ Cache Busting in React / Vite React projectda frontend’ga yangi feature (xususiyat) qoβ€˜shdim va saytni deploy qildim. Leki
πŸ—‚ Cache Busting in React / Vite React projectda frontend’ga yangi feature (xususiyat) qoβ€˜shdim va saytni deploy qildim. Lekin ayrim brauzerlarda eski versiya chiqib qolmoqda. Bu holat caching muammosi bilan bogβ€˜liq
Frontend loyihalar (masalan, React) yangilanganda, foydalanuvchilarning brauzeri koβ€˜pincha eski fayllarni keshlangan (cache) holatda saqlab qoladi.
Brauzer har doim har bir faylni qayta yuklab olish oβ€˜rniga, uni bir marta yuklab olgach, keyingi marta site'ga kirilganda aynan oβ€˜sha faylni cache’dan olib foydalanadi. Muammo shundaki, loyiha build qilinganda fayllar yangilansa ham, ularning nomi (main.js kabi) oβ€˜zgarmasligi mumkin. Natijada foydalanuvchi sayt'ga kirganda, brauzer fayl nomi bir xil boβ€˜lgani uchun uni eski versiyadan – ya’ni cache’dan olib ishlatadi. Shuning uchun yangi oβ€˜zgarishlar koβ€˜rinmaydi. "Cache Busting" β€” bu yangi fayllarni avtomatik ravishda yangi nom bilan yaratish usuli. Har safar build qilinganda fayl nomiga hash qoβ€˜shiladi, hash bu raqam va harflar'dan tashkil topgan birikma. Project har build qilinganda, o'zgarish kiritilgan file'da hash o'zgaradi Masalan:
main.js β†’ main.a3f5s3.js
Shunda brauzer bu faylni yangi fayl deb biladi va cache oβ€˜rniga yangisini yuklaydi. React (Vite) loyihada, vite.config.ts fayl'dagi build'ga rollupOptions qo'shish orqali Cache Busting qilish mumkin:
export default defineConfig({
  build: {
    outDir: 'dist',
    assetsDir: 'assets',
    rollupOptions: {
      output: {
        entryFileNames: 'assets/[name].[hash].js',
        chunkFileNames: 'assets/[name].[hash].js',
        assetFileNames: 'assets/[name].[hash].[ext]',
      },
    },
  },
})
Bu konfiguratsiya har bir faylni hash bilan nomlaydi, shunda brauzer eskisini emas, yangisini yuklaydi. πŸ”— keycdn.com/support/what-is-cache-busting πŸ”— maxtsh.medium.com/the-ultimate-guide-to-cache-busting-for-react-production-applications-d583e4248f02 #reactjs #vite #cache #busting βœ… @JasXDev

βš™οΈ Kichik Experiment React component'ni Angular project'da ishlatib ko'rdim. React kutubxonani o'rnatib olamiz npm install re
βš™οΈ Kichik Experiment
React component'ni Angular project'da ishlatib ko'rdim.
React kutubxonani o'rnatib olamiz
npm install react react-dom
* package.json
{
     .....
     "react": "^19.1.0",
     "react-dom": "^19.1.0",
     .....
}
TypeScript bilan ishlash uchun kerakli @type kutubxonalarni ham oβ€˜rnatamiz
npm install --save-dev @types/react @types/react-dom
* tsconfig.json
{
  "compilerOptions": {
    "jsx": "react"
  }
}
React component yaratamiz (e.g. src/react/HelloReact.tsx)
import React from 'react';

const HelloReact = () => {
  return <div>Hello from React!</div>;
};

export default HelloReact;
Yaratilgan React component'ni DOM'ga joylashtirish (render qilish) uchun ReactWrapper funksiya yozamiz.
import React from 'react';
import ReactDOM from 'react-dom/client';
import HelloReact from './HelloReact';

export function renderReactComponent(container: HTMLElement) {
  const root = ReactDOM.createRoot(container);
  root.render(<HelloReact />);
}
Bu funksiyada ReactDOM.createRoot() orqali React komponentini render qilamiz. React oβ€˜zining virtual DOM mexanizmi yordamida HelloReact komponentini HTML elementga aylantiradi.
@Component({
  selector: 'app-react-wrapper',
  template: `<div id="react-root"></div>`,
  standalone: true,
})

export class ReactWrapperComponent implements AfterViewInit {
  constructor(private elRef: ElementRef) {}

  ngAfterViewInit() {
    const container = this.elRef.nativeElement.querySelector('#react-root');
    renderReactComponent(container);
  }
}
ReactWrapperComponent vazifasi, Render qiling React component'ni Angular componentda ochilgan <div id="react-root"></div>'ga joylash. AfterViewInit β€” bu Angular lifecycle metodi hisoblanadi. Uning vazifasi - ngAfterViewInit funksiyasi ichidagi kodlarni komponentning barcha view elementlari toβ€˜liq render qilingandan keyin ishga tushirishdir. AfterViewInit - angular.dev/api/core/AfterViewInit Hosil bo'lgan Angular component'ni istalgan joy'da foydalana olamiz
<app-react-wrapper></app-react-wrapper>
πŸ”— medium.com/@zacky_14189/embedding-react-components-in-angular-the-easy-way-60f796b68aef #react #angular πŸ’  @JasXDev

πŸ”‹ Lazy loading Lazy loading - bu veb-sahifaning ma’lum qismlarini foydalanuvchi yoki brauzerga kerak bo'lmaguncha yuklamasda
πŸ”‹ Lazy loading
Lazy loading - bu veb-sahifaning ma’lum qismlarini foydalanuvchi yoki brauzerga kerak bo'lmaguncha yuklamasdan kutib turish (render qilish jarayonini to'xtatib turish)
Hammasini birdaniga yuklash (eager loading) oβ€˜rniga, brauzer ba’zi resurslarni faqat foydalanuvchiga kerak sahifa bilan oβ€˜zaro aloqaga kirishgandan keyin soβ€˜raydi. Agar Lazy loading toβ€˜gβ€˜ri amalga oshirilsa, sahifaning yuklanish tezligini oshirishga yordam beradi. Bu turdagi yuklash 'dangasa' (lazy) deb ataladi, chunki u brauzerni ishini kechiktirishga undaydi. Masalan, blog postda sahifaning yuqori qismida rasm, pastki qismida diagramma bor deb faraz qilaylik. Blog postini oβ€˜qiyotgan foydalanuvchi bir necha daqiqa davomida matnning pastki qismiga yetib bormasligi mumkin, shuning uchun brauzer foydalanuvchi oβ€˜sha boβ€˜limga oβ€˜tmaguncha diagrammani yuklashni kutadi. Shunday qilib, sahifa dastlab tezroq yuklanadi, chunki brauzer ikkita rasm oβ€˜rniga bitta rasm yuklamoqda. Veb-sahifa yuklanganda, foydalanuvchi koβ€˜rayotgan qismi 'yuqori qism' (above the fold) deb ataladi, foydalanuvchi hali koβ€˜rmayotgan qismi esa 'quyi qism' (below the fold) deb ataladi.
"above the fold" va "below the fold" gazeta maketlaridan kelib chiqqan. Gazetalar, odatda, gorizontal boβ€˜yicha ikkiga buklangan, oldingi yarmi esa buklangan joydan yuqorida joylashgan boβ€˜ladi.
* Rasmlar uchun lazy loading amalga oshirish Lazy loading-ni amalga oshirishning bir usuli β€” bu img tegida loading atributidan foydalanish. Quyidagi misolda koβ€˜rsatilganidek, loading="lazy" qoβ€˜shish brauzerga foydalanuvchi rasmga yaqinlashguncha uni yuklamaslikni buyuradi
<img src="example.com/image" loading="lazy">
* Eager loading nima ? Eager loading β€” bu barcha veb-sahifa resurslarini bir vaqtning oβ€˜zida yuklash jarayoni. Murakkab va kodi koβ€˜p boβ€˜lgan veb-ilovalar, masalan, onlayn oβ€˜yinlar, koβ€˜pincha eager loading'dan foydalanishni afzal koβ€˜radi.
<img src="example.com/image" loading="eager">
loading="eager" atributidan foydalanildi, bu esa rasmni darhol yuklashni ta'minlaydigan standart hisoblanadi. Bu, darhol ko'rilishi kerak bo'lgan muhim rasmlar uchun ishlatilinadi. image tag'da default holatda loading attribute qiymati eager bo'ladi πŸ”— cloudflare.com/learning/performance/what-is-lazy-loading βš™οΈ React Lazy Loading React'da component dinamik tarzda yuklanish uchun, React.lazy funksiyasi ishlatilinadi Odatda, Lazy loading React ilovalarida ko'p ishlatilmaydi, chunki React ko'pincha bitta sahifali ilovalar (SPA) yaratish uchun ishlatiladi. React odatda butun ilovani bitta faylga birlashtiradi (bundle qiladi). Misol: Lazy Loading Component
import React, { Suspense } from "react";

const LazyComponent = React.lazy(() => import("./LazyComponent"));

function App() {
  return (
    <div>
      <h1>Welcome to My App</h1>
      <Suspense fallback={<div>Loading...</div>}>
        <LazyComponent />
      </Suspense>
    </div>
  );
}

export default App;
React.lazy faqat LazyComponent render qilinganda dinamik ravishda import qiladi. Suspense fallback komponent yuklanayotgan paytda zaxira UI taqdim etadi (loader). πŸ“Ή youtu.be/KcbPpVeDqKA?si=2_eFmDXsVeC3--AR βš™οΈ Angular Lazy Loading Default holatda, NgModul'lar tezda yuklanadi. Bu shuni anglatadiki, ilova yuklanganda, barcha NgModul'lar darhol yuklanadi, ular hozirgi vaqtda zarur yoki yo'qligiga qaramay. Lazy loading dastlabki paket (bundle) o'lchamlarini kichikroq saqlashga yordam beradi, bu esa yuklash vaqtlarini qisqartirishga yordam beradi. Angular modullarini lazy loading qilish uchun AppRoutingModule routing konfiguratsiyasida component o'rniga loadChildren'dan foydalaniladi
const routes: Routes = [
  {
    path: 'items',
    loadChildren: () => import('./items.module').then(m => m.ItemsModule)
  }
];
πŸ”— v17.angular.io/guide/lazy-loading-ngmodules πŸ“Ή youtu.be/NFJbXP6Ci98?si=tutzScmyavxQbYim #lazyLoading #react #angular βœ… @JasXDev

πŸ—‚ Linked List in Javascript (2- qism) Yuqorida ta’kidlanganidek, ListNode ikkita elementni oβ€˜z ichiga oladi: ma’lumotlar va
πŸ—‚ Linked List in Javascript (2- qism) Yuqorida ta’kidlanganidek, ListNode ikkita elementni oβ€˜z ichiga oladi: ma’lumotlar va keyingi node'ning manzili. * Node Class & Constructor LinkedList class yaratishdan oldin, ListNode yaratishimiz kerak. LinkedList'ni tashkil etuvchi node'larni yaratish uchun class Node ishlatiladi. Har bir node data xossasiga va next xossaga ega boβ€˜ladi. data xususiyati node'da saqlanadigan ma’lumotlarni saqlaydi. next xususiyat LinkedList'ning keyingi node'ga ishora qiladi. JavaScriptda ListNode'ni quyidagicha amalga oshirishimiz mumkin:
class Node {
    constructor(data) {
        this.data = data
        this.next = null                
    }
}
this.data = data - Node class'ga uzatilgan ma’lumotlar joriy obyektning data xususiyatiga saqlanadi. this.next = null node'ning next xossasiga null'ga oβ€˜rnatadi. * Linked List Class & Constructor Endi Node Class'ga ega boβ€˜lganimiz sababli, biz LinkedList class'ni yaratishimiz mumkin. LinkedList Class head va tail xususiyatlariga ega. Head - LinkedList'dagi birinchi node'ga ishora qiladi. Tail - LinkedList'dagi oxirgi node'ga ishora qiladi. Agar LinkedList bo'sh bo'lsa ya'ni bironta node mavjud bo'lmasa head va tail qiymati null'ga teng bo'ladi
class LinkedList {
   constructor() {
    this.head = null;
    this.tail = null;
  }
}
* Yangi node qo'shish add() method LinkedList'ning oxiriga yangi node qo'shadi. Agar List'ning birinchi elementi (head) null qiymatga ega bo'lsa, yangi node head'ga biriktiriladi. Agar head qiymatga ega bo'lsa, yangi node tail'ga biriktiriladi. Ushbu usulning time complexity'si O (1) ga teng, chunki u yangi node'ni qoβ€˜shish uchun LinkedList orqali loop oβ€˜tishi shart emas.
add(data) {
  const node = new Node(data);

  if (this.head === null) {
    this.head = node;
  } else {
    this.tail.next = node;
  }

  this.tail = node;
* Linked List Loop PrintAll usuli head node'dan boshlanadi va har bir node orqali tail node'ga yetguncha takrorlanadi.
  printAll() {
    let current = this.head;

    while (current !== null) {
      console.log(current.data);
      current = current.next;
    }
  }
Endi biz buni yangi LinkedList yaratish va unga ba’zi node'larni qoβ€˜shish orqali sinab koβ€˜rishimiz mumkin.
const list = new LinkedList();

list.add(1);
list.add(2);
list.add(3);
list.add(4);

list.printAll();
* Ma'lum bir index'dagi node'ni olish get usuli node'ning ma’lumotlarini koβ€˜rsatilgan indeks'da qaytaradi. U indeks qiymatini qabul qiladi va koβ€˜rsatilgan indeksdagi node'ga yetib borguncha LinkedList orqali takrorlanadi. Keyin oβ€˜sha node'ning ma’lumotlarini qaytaradi. Ushbu usulning time complexity'si O(n) ga teng, chunki u koβ€˜rsatilgan indeksdagi node'ni topish uchun LinkedList orqali oβ€˜tishi kerak. Massivlar buning uchun yaxshiroq variant, chunki ular istalgan vaqt kirish imkoniyatiga ega. Massivdagi elementga murojaat qilishning time complexity'gi O(1) ga teng.
 get(index) {
    let current = this.head;
    let i = 0;

    while (i < index) {
      current = current.next;
      i++;
    }

    return current.data;
  }
πŸ‘¨β€πŸ’» https://github.com/bradtraversy/traversy-js-challenges/blob/main/07-stacks-queues-linked-lists/10-linked-list-implementation/readme.md πŸ“Ή https://youtu.be/ZBdE8DElQQU?si=S2P__kh9HkIO61MT πŸ”— https://www.freecodecamp.org/news/implementing-a-linked-list-in-javascript/ #algorithm #linkedList #js βœ… @JasXDev