Objasnite JavaScript zapise?

Objasnite Javascript Zapise



JavaScript dolazi s neprimitivnim tipom podataka ' Objekt ” koja je izvedena uz pomoć primitivnih (ugrađenih) tipova podataka. “Objekt” djeluje kao instanca za pristup JavaScript članovima. Koristi se za pozivanje JavaScript funkcije za izvođenje specifičnih zadataka koje primitivni tipovi podataka ne mogu. Međutim, jedan nedostatak ove vrste podataka je taj što izvodi operaciju usporedbe na temelju svog identiteta, a ne sadržaja. Za rješavanje ovog problema JavaScript nudi novi tip podataka ' Zapisi ” jer striktno uspoređuje na temelju svog sadržaja, a ne identiteta.

Ovaj vodič objašnjava JavaScript zapise.







Što su 'Zapisi'?

JavaScript” Zapisi ” je novi primitivni tip (nizovi, brojevi, simboli) sličan ugrađenom . Jedina je razlika u tome što su 'Zapisi' potpuno nepromjenjivi, tj. vrijednost njihovih ključeva ne može se promijeniti nakon što su inicijalizirani.



Sintaksa



Sintaksa ' Snimiti ” identičan je “Objektu”, ali zahtijeva “ # (hash)” ispred vitičastih zagrada koje ga označavaju kao “Record”:





const snimljeno ime = #{
/*
ključ: vrijednost
/*
}


Upotrijebimo gore navedenu sintaksu za stvaranje novog zapisa.

Kako stvoriti zapise?

Da biste stvorili zapis, navedite simbol '#(hash)' na početku vitičastih zagrada kao što je prikazano u donjem bloku koda:



const osoba = #{
fname: 'Ili' ,
ime: 'Usman' ,
dob: dvadeset i jedan ,
}
konzola.log ( osoba.fname )
konzola.log ( osoba.ime )
konzola.log ( osoba.dob )


U gornjem bloku koda:

    • ' osoba ” odnosi se na novi “Zapis” koji ima sljedeće ključeve “fname”, “lname” i “age”.
    • Zatim, ' konzola. log() ” prikazuje ključne vrijednosti osobe jednu po jednu.

Bilješka: Korisnik također može odrediti sadržaj 'Zapisi' u jednom retku ovako:

const osoba = #{fname: 'Ali', lname: 'Usman', dob: 21}


Izlaz


Može se vidjeti da izlaz prikazuje sve ključne vrijednosti kreirane Zapisne “osobe”.

Ograničenje zapisa

“Record” ne prihvaća “Array” i “Object” kao svoj ključ. Ako ih korisnik proslijedi zapisu, kompajler generira ' TypeError ”. Sljedeći blok koda to praktično prikazuje:

const novi zapis = #{
dolazak: [ 'HTML' , 'CSS' , 'JavaScript' ]
}
konzola.log ( osoba.arr )


U gornjim linijama koda:

    • ' novi rekord ” inicijalizira niz pod nazivom “arr” kao svoj ključ.
    • Zatim, ' konzola. log() ” prikazuje vrijednost ključa „arr” navedenu u „newRecord”.

Izlaz


Konzola prikazuje 'TypeError (prosljeđivanje neočekivanog tipa)' jer 'Records' ne prihvaća niz kao ključ.

Razumijevanje JavaScript zapisa korištenjem primjera

Ovaj odjeljak sadrži praktične upotrebe 'Zapisa' uz pomoć danih primjera.

Počnimo s prvim primjerom.

Primjer 1: Zapisi su duboko nepromjenjivi

JavaScript” Zapisi ” su duboko nepromjenjivi primitivni tipovi. 'Duboko nepromjenjivo' znači da se sve ključne vrijednosti zapisa ne mogu modificirati ili promijeniti ni na jednoj razini nakon što su postavljene. 'Primitivni' tipovi označavaju sve osnovne JavaScript tipove podataka kao što su niz, broj, null, nedefinirano i mnogi drugi.

Sljedeći blok koda praktično prikazuje navedeni koncept:

const myRecord = #{
Ime: 'Ili' ,
dob: dvadeset i jedan ,
}
myRecord.name= 'Haroon'


U gornjem bloku koda, ' mojZapis ' ključ ' Ime ” vrijednost se mijenja nakon inicijalizacije.

Izlaz


Može se uočiti da kompajler pokazuje 'TypeError' pri modificiranju vrijednosti ključa 'newRecord'.

Primjer 2: Zapisi su usporedni

Glavna prednost “Zapisa” je to što se uspoređuju na temelju svojih vrijednosti, a ne identiteta. Dok se 'Objekti' uspoređuju prema svojim identitetima, a ne prema vrijednostima. Ako su dvije vrijednosti zapisa jednake tada prevodilac dohvaća true.

Pogledajmo to praktično uz pomoć zadanih linija koda:

const myRecord = #{
Ime: 'Ili' ,
dob: dvadeset i jedan ,
}
konzola.log ( moj Zapis === #{
Ime: 'Ili' ,
dob: dvadeset i jedan ,
} ) ;


Ovdje gornji isječak koda stvara dva zapisa koji se uspoređuju uz pomoć ' stroga jednakost (===)” operator.

Izlaz


Izlaz vraća ' pravi ” Booleova vrijednost koja znači da su navedeni operatori, tj. “Zapisi” jednaki.

Primjer 3: Pretvaranje zapisa u objekt

JavaScript “Zapisi” također se mogu pretvoriti u tip podataka “Object” uz pomoć konstruktora “Object”. Evo njegove praktične primjene:

neka moj zapis = #{ Jedan: 1, Dva: 2 }
konzola.log ( Objekt ( mojZapis ) )
konzola.log ( vrsta mog zapisa )


U gornjim redcima koda:

    • Prvi ' lconsole.and() ” koristi konstruktor “Object” za pretvaranje “ mojZapis ” u “objekt.
    • Druga metoda 'console.log()' koristi ' vrsta ” ključna riječ za provjeru tipa „myRecord”.

Izlaz


Izlaz prikazuje pretvoreni 'newRecord' kao ' Objekt ” koji potvrđuje da je “newRecord” uspješno pretvoren u “objekt”.

Primjer 4: Pretvaranje objekta u zapis

Korisnik također može pretvoriti 'Object' u 'Record' za potrebe usporedbe uz pomoć ' Snimiti() ” metoda. Učinimo to praktično:

neka mojObj = { Jedan: 1 , dva: 2 }
neka myRecord = Zapis ( mojObj )
konzola.log ( mojZapis )


Sada, gornji isječak koda koristi ' Snimiti() ” za pretvaranje zadanog objekta „myObj” u „myRecord”.

Izlaz


Izlaz uspješno prikazuje konvertirani objekt 'myObj' u sadržaj 'myRecord'.

Primjer 5: Stvaranje novih zapisa iz postojećih zapisa

Kao što je objašnjeno u prvom primjeru, 'Zapisi' su nepromjenjivi, tj. njihove ključne vrijednosti ne mogu se mijenjati. Međutim, korisnik može stvoriti novi 'Zapis' iz postojećeg 'Zapisa' uz dodavanje nekih drugih vrijednosti.

Slijedite dani isječak koda da biste stvorili novi zapis iz postojećeg:

neka stari zapis = #{A: 1, B: 2};
neka novi zapis = #{ ...myRecord, C: 3, D:4}
konzola.log ( novi rekord )


U gornjem JavaScript kodu:

    • ' stari zapis ” odnosi se na postojeći zapis koji ima dvije ključne vrijednosti.
    • Sljedeći ' novi rekord ” odgovara novom zapisu koji je kreiran uz pomoć postojećeg “oldRecord” i također dodavanjem novih navedenih ključnih vrijednosti.
    • Na kraju, ' konzola. log() ” prikazuje novostvoreni zapis pod nazivom “newRecord”.

Izlaz


Izlaz prikazuje sve ključne vrijednosti novostvorenog zapisa.

Primjer 6: Pristup zapisima korištenjem metode “Object.keys()”.

Korisnik može koristiti ugrađeni JavaScript “ ključevi () 'metoda' Objekt ” za pristup ključevima Zapisa. U ovom scenariju koristi se za pristup tipkama 'myRecord':

neka moj zapis = #{A: 1, B: 2};
neka recordKeys = Object.keys ( mojZapis ) ;
konzola.log ( recordKeys )


Gornji isječak koda koristi ' Object.keys() ” za pristup svim ključevima prisutnim u “myRecord”.

Izlaz


Izlaz prikazuje sve ključeve 'myRecord' u formatu niza i također s njihovim indeksima u formatu para ključ-vrijednost.

Zaključak

JavaScript” Zapisi ” su tip podataka napredne razine koji je duboko nepromjenjiv. Djeluje slično kao 'Objekt', ali glavna razlika je u tome što se njegova vrijednost može promijeniti ili ažurirati nakon što je postavljena. Zahtijeva simbol '#(hash)' prije vitičastih zagrada za deklaraciju, inače se ponaša kao objekt. Ovaj vodič ukratko objašnjava vrstu podataka JavaScript Records.