Jasur - IT Blog
Kanalga Telegramโda oโtish
- @jasurkhaitov Bilganlarim va foydali bo'lishi mumkin bo'lgan ma'lumotlarini ulashib boraman. - github.com/jasurkhaitov - jasurkhaitov.uz
Ko'proq ko'rsatishMamlakat belgilanmaganTexnologiyalar & Aralashmalar59 258
96
Obunachilar
Ma'lumot yo'q24 soatlar
-17 kunlar
-330 kunlar
Postlar arxiv
+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+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 manzil (reference) saqlanadiJavaScriptโ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
@JasXDevRepost 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 strukturasiBrowser 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๐จโ๐ป "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๐ 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
* 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 hisoblanadiQulay 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. 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 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 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 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
Endi mavjud! Telegram Tadqiqoti 2025 โ yilning asosiy insaytlari 
