Selgitage JavaScripti kirjeid?

Selgitage Javascripti Kirjeid



JavaScript on varustatud mitteprimitiivse andmetüübiga ' Objekt ”, mis tuletatakse primitiivsete (sisseehitatud) andmetüüpide abil. 'Objekt' toimib JavaScripti liikmetele juurdepääsuks. Seda kasutatakse JavaScripti funktsiooni käivitamiseks konkreetse ülesande täitmiseks, mida primitiivsed andmetüübid ei suuda. Selle andmetüübi üks puudus on aga see, et see teostab võrdlustoimingut oma identiteedi, mitte sisu alusel. Selle probleemi lahendamiseks pakub JavaScript uut andmetüüpi ' Rekordid ”, kuna see võrdleb rangelt selle sisu, mitte identiteedi alusel.

See juhend selgitab JavaScripti kirjeid.







Mis on 'Rekordid'?

JavaScript ' Rekordid ” on uus primitiivne tüüp (stringid, numbrid, sümbolid), mis sarnaneb sisseehitatud tüübiga . Ainus erinevus seisneb selles, et 'Kirjed' on puhtalt muutumatud, st nende võtmete väärtust ei saa pärast nende lähtestamist muuta.



Süntaks



Süntaks ' Salvestus ' on identne 'objektiga', kuid see nõuab ' # (räsi)' sümbol enne lokkis sulgusid, mis tähistavad seda kui 'Salvesta':





const recoredName = #{
/*
võti: väärtus
/*
}


Kasutame uue kirje loomiseks ülaltoodud süntaksit.

Kuidas rekordeid luua?

Kirje loomiseks määrake kõverate sulgude alguses sümbol „#(räsi)”, nagu on näidatud allolevas koodiplokis:



const isik = #{
fname: 'või' ,
lnimi: 'Usman' ,
vanus: kakskümmend üks ,
}
console.log ( isik.fnimi )
console.log ( isik.lnimi )
console.log ( inimene.vanus )


Ülaltoodud koodiplokis:

    • ' isik ” viitab uuele „Kirjele”, millel on järgmised võtmed „fname”, „lname” ja „vanus”.
    • Järgmiseks ' konsool. logi() ” meetod kuvab vastavalt ükshaaval “person” võtmeväärtused.

Märge: Kasutaja saab määrata ka 'Kirjed' sisu ühel real järgmiselt:

const isik = #{fnimi: 'Ali', lnimi: 'Usman', vanus: 21}


Väljund


On näha, et väljundis kuvatakse kõik loodud kirje “isik” võtmeväärtused.

Kirjete piirang

'Kirje' ei aktsepteeri 'massiivi' ja 'objekti' võtmena. Kui kasutaja edastab need kirjele, genereerib kompilaator ' Tüübiviga ”. Järgmine koodiplokk näitab seda praktiliselt:

const newRecord = #{
arr: [ 'HTML' , 'CSS' , 'JavaScript' ]
}
console.log ( isik.arr )


Ülaltoodud koodiridades:

    • ' uusRekord ” lähtestab võtmeks massiivi nimega “arr”.
    • Järgmiseks ' konsool. logi() ” kuvab “newRecord”-s määratud “arr” võtme väärtus.

Väljund


Konsool kuvab teadet 'TypeError(passing unoexpected type)', kuna kirje 'Records' ei aktsepteeri massiivi võtmena.

JavaScripti kirjete mõistmine näidete abil

See osa hõlmab 'Kirjete' kasutusvõimalusi praktiliselt toodud näidete abil.

Alustame esimese näitega.

Näide 1: Kirjed on sügavalt muutumatud

JavaScript ' Rekordid ” on sügavalt muutumatud primitiivsed tüübid. 'Sügavalt muutumatu' tähendab, et kõiki kirje võtmeväärtusi ei saa pärast seadistamist ühelgi tasemel muuta ega muuta. 'Primitiivsed' tüübid tähistavad kõiki põhilisi JavaScripti andmetüüpe, nagu string, number, null, undefined ja paljud teised.

Järgmine koodiplokk näitab esitatud kontseptsiooni praktiliselt:

const myRecord = #{
nimi: 'või' ,
vanus: kakskümmend üks ,
}
myRecord.name= 'Haaroon'


Ülaltoodud koodiplokis on ' myRecord ' võti ' nimi ” väärtust muudetakse pärast selle lähtestamist.

Väljund


Võib täheldada, et kompilaator näitab 'newRecord' võtme väärtuse muutmisel 'TypeError'.

Näide 2: kirjed on võrdlevad

“Rekordite” peamine eelis seisneb selles, et neid võrreldakse väärtuste, mitte identiteedi alusel. Kusjuures 'Objektid' võrdlevad oma identiteeti, mitte väärtusi. Kui kaks kirje väärtust on võrdsed, otsib kompilaator tõese.

Vaatame seda antud koodiridade abil praktiliselt:

const myRecord = #{
nimi: 'või' ,
vanus: kakskümmend üks ,
}
console.log ( myRecord === #{
nimi: 'või' ,
vanus: kakskümmend üks ,
} ) ;


Siin loob ülaltoodud koodilõik kaks kirjet, mida võrreldakse ' range võrdsus (===)” operaator.

Väljund


Väljund tagastab ' tõsi ” Boolean väärtus, mis tähendab, et määratud operaatorid, st “Kirjed” on võrdsed.

Näide 3: teisenda kirje objektiks

JavaScripti “Records” saab ka “Object” konstruktori abil teisendada andmetüübiks “Object”. Siin on selle praktiline rakendamine:

lase myRecord = #{ Üks: 1, kaks: 2 }
console.log ( Objekt ( myRecord ) )
console.log ( myRecordi tüüp )


Ülaltoodud koodiridades:

    • Esimene ' lconsole.and() ' meetod kasutab 'Object' konstruktorit ' myRecord ” objektiks.
    • Teine 'console.log()' meetod kasutab ' tüüp ” märksõna „myRecord” tüübi kontrollimiseks.

Väljund


Väljund näitab teisendatud 'newRecord' kui ' Objekt tüüp, mis kinnitab, et 'newRecord' on edukalt 'objektiks' teisendatud.

Näide 4: teisenda objekt kirjeks

Samuti saab kasutaja 'objekti' teisendada 'kirjeks' võrdluse eesmärgil, kasutades ' Salvestus() ” meetod. Teeme seda praktiliselt:

lase myObj = { Üks: 1 , Kaks: 2 }
lase myRecord = Salvestus ( myObj )
console.log ( myRecord )


Nüüd kasutab ülaltoodud koodilõik Salvestus() ” meetod, et teisendada antud 'myObj' objekt 'myRecordiks'.

Väljund


Väljund näitab edukalt teisendatud objekti 'myObj' 'myRecord' sisuks.

Näide 5: Looge olemasolevatest kirjetest uued kirjed

Nagu esimeses näites kirjeldatud, on kirjed muutumatud, st nende võtmeväärtusi ei saa muuta. Siiski saab kasutaja olemasolevast kirjest koos mõne muu väärtuse lisamisega luua uue kirje.

Olemasolevast kirjest uue kirje loomiseks järgige antud koodilõiku:

lase oldRecord = #{A: 1, B: 2};
lase uusRekord = #{ ...myRecord, C: 3, D:4}
console.log ( uusRekord )


Ülaltoodud JavaScripti koodis:

    • ' vanaRecord ” viitab olemasolevale kirjele, millel on kaks võtmeväärtust.
    • Järgmisena ' uusRekord ” vastab uuele kirjele, mis luuakse olemasoleva “oldRecord” abil ja ka uute määratud võtmeväärtuste lisamisega.
    • Lõpuks, ' konsool. logi() ” kuvab vastloodud kirje nimega “newRecord”.

Väljund


Väljund kuvab kõik vastloodud kirje võtmeväärtused.

Näide 6: Juurdepääs kirjetele, kasutades 'Object.keys()' meetodit

Kasutaja saab kasutada sisseehitatud JavaScripti ' võtmed () ' meetod ' Objekt , et pääseda ligi kirje klahvidele. Selle stsenaariumi korral kasutatakse seda 'myRecord' klahvidele juurdepääsuks:

lase myRecord = #{A: 1, B: 2};
lase recordKeys = Object.keys ( myRecord ) ;
console.log ( rekordKeys )


Ülaltoodud koodilõik kasutab Object.keys() ” meetod, et pääseda juurde kõikidele „myRecordis” leiduvatele võtmetele.

Väljund


Väljund näitab kõiki “myRecord” võtmeid massiivivormingus ja ka nende indekseid võtme-väärtuspaari vormingus.

Järeldus

JavaScript ' Rekordid ” on kõrgtaseme andmetüüp, mis on sügavalt muutumatu. See töötab sarnaselt objektiga, kuid peamine erinevus seisneb selles, et selle väärtust saab pärast seadistamist muuta või värskendada. See nõuab deklaratsiooni lokkis sulgude ees sümbolit '# (räsi)', vastasel juhul toimib see objektina. Selles juhendis selgitati lühidalt JavaScripti kirjete andmetüüpi.