欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript第七種數(shù)據(jù)類型Symbol的用法詳解

 更新時(shí)間:2022年09月08日 10:30:20   作者:前端--末晨曦吖  
Symbol是ES6中引入的一種新的基本數(shù)據(jù)類型,用于表示一個(gè)獨(dú)一無二的值。它是JavaScript中的第七種數(shù)據(jù)類型。本文將詳細(xì)講講Symbol的使用,需要的可以參考一下

一、什么是Symbol

Symbol是ES6中引入的一種新的基本數(shù)據(jù)類型,用于表示一個(gè)獨(dú)一無二的值。它是JavaScript中的第七種數(shù)據(jù)類型,與undefined、null、Number(數(shù)值)、String(字符串)、Boolean(布爾值)、Object(對(duì)象)并列。

Symbol特點(diǎn):

  • Symbol的值是唯一的,用來解決命名沖突問題
  • Symbol值不能與其他數(shù)據(jù)進(jìn)行運(yùn)算
  • Symbol定義的對(duì)象屬性不能使用for...in循環(huán)遍歷,但是可以使用Reflect.ownKeys來獲取對(duì)象的所有鍵名

基本用法:

let a = Symbol("末晨曦吖");
console.log(a); // Symbol(末晨曦吖)
console.log(typeof a); //symbol

// 相同參數(shù) Symbol() 返回的值不相等
let b = Symbol("末晨曦吖");
console.log(a === b); //false

為什么相同參數(shù) Symbol() 返回的值不相等???

因?yàn)槭褂肧ymbol()創(chuàng)建一個(gè)Symbol類型的值并賦值給a變量后,你就得到了一個(gè)在內(nèi)存中獨(dú)一無二的值。現(xiàn)在除了通過變量a,任何人在任何作用域內(nèi)都無法重新創(chuàng)建出這個(gè)值。所以就算我們通過相同參數(shù)創(chuàng)建的b,結(jié)果還是不相等的。

盡管a和b都是使用Symbol()創(chuàng)建出來的,但是它們?cè)趦?nèi)存中看起來卻是這樣的:

實(shí)際上,a變量拿到了內(nèi)存中某塊內(nèi)存的唯一引用(這里所說的引用,其實(shí)就是該內(nèi)存的地址)。如果不借助a變量,你不可能再得到這個(gè)地址。因此:

a !== b;  //a和b持有的是兩塊內(nèi)存的引用
 
const c = a;  //手動(dòng)把a(bǔ)里保存的地址保存在c變量中
a === c;  //c和a現(xiàn)在指向同一塊內(nèi)存,因?yàn)樗鼈儽4媪送瑯拥牡刂?

這種行為看似難以理解,但其實(shí)它與對(duì)象遵循相同的規(guī)則,如:

let a = {};
let b = {};
 
a !== b;  //a和b各自被分配了不同的內(nèi)存,因此它們保存了不同的地址
 
//借助變量a,變量c拿到了a指向的那個(gè)對(duì)象的地址,因此兩者相等
let c = a;
a === c;

但是對(duì)于同為基本數(shù)據(jù)類型的字符串來說,它不遵循類似的規(guī)則。比如:

let a = "123";
let b = "123";
 
a === b;  //返回true。兩者在常量區(qū)引用同一個(gè)字符串

我們首先通過變量a在內(nèi)存中創(chuàng)建了字符串“123”,然后在不借助變量a的情況下,又通過var b = "123"拿到了對(duì)“123”這個(gè)字符串的引用,兩者指向內(nèi)存中的同一塊內(nèi)存地址。

因此我們說,a無法確保別的變量無法拿到它保存的地址(前提是不通過a)。但是對(duì)于var a = Symbol()這樣的語句,a變量內(nèi)保存的值是唯一的,因?yàn)槌私柚鷄變量,你永遠(yuǎn)無法得到a中保存的值。這也是Symbol的本質(zhì)。

二、作為屬性名的Symbol

let mySymbol = Symbol();
// 第一種寫法
let a = {};
a[mySymbol] = 'Hello!';
// 第二種寫法
let a = {
  [mySymbol]: 'Hello!'
};
// 第三種寫法
let a = {};
Object.defineProperty(a, mySymbol, { value: 'Hello!' });
// 以上寫法都得到同樣結(jié)果
a[mySymbol] // "Hello!"
注意,Symbol值作為對(duì)象屬性名時(shí),不能用點(diǎn)運(yùn)算符。

let a = {};
let name = Symbol();
a.name = 'lili';
a[name] = 'lucy';
console.log(a.name,a[name]);//lili,lucy
Symbol值作為屬性名時(shí),該屬性還是公開屬性,不是私有屬性。

三、Symbol中的方法

1、Symbol.for()

我們知道Symbo()創(chuàng)建的兩個(gè)變量永遠(yuǎn)不會(huì)是相同的。那么如果我們需要重新使用同一個(gè)Symbol怎么辦,總不能需要挨個(gè)去進(jìn)行比較吧。還好,es6為我們提供了Symbol.for()方法?!?/p>

參數(shù)是symbol類型的描述信息,不同于Symbol(),這個(gè)而參數(shù)只能是字符串或者是undefined,若已經(jīng)創(chuàng)建了則返回這個(gè)symbol,否則就進(jìn)行創(chuàng)建并將這個(gè)新的symbol返回,代碼如下

let name = Symbol.for("末晨曦");
let name1 = Symbol.for("末晨曦");
console.log(name === name1);  // true

請(qǐng)注意,我們?cè)谑褂脛?chuàng)建描述信息為"末晨曦"的變量的時(shí)候,使用的是for,而不是Symbol(),倘若使用Symbol()進(jìn)行首次創(chuàng)建,for會(huì)再次創(chuàng)建一次,二者不會(huì)相等,代碼如下:

let name = Symbol("末晨曦");
let name1 = Symbol.for("末晨曦");
console.log(name === name1);  // false

原因在于Symbol.for()會(huì)有一個(gè)登記機(jī)制,使用for只會(huì)對(duì)通過for創(chuàng)建的symbol進(jìn)行檢查,不會(huì)對(duì)Symbol()創(chuàng)建的進(jìn)行檢查。

2、Symbol.keyFor()

這個(gè)方法參數(shù)是一個(gè)通過Symbol.for()創(chuàng)建的symbol類型變量,返回這個(gè)symbol變量的描述信息。

let name = Symbol.for("末晨曦");
console.log(Symbol.keyFor(name)); // "末晨曦"
let name1 = Symbol("末晨曦");
console.log(Symbol.keyFor(name1)); // undefined 不能查找Symbol()創(chuàng)建的變量

到此這篇關(guān)于JavaScript第七種數(shù)據(jù)類型Symbol的用法詳解的文章就介紹到這了,更多相關(guān)JavaScript Symbol內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • toString()一個(gè)會(huì)自動(dòng)調(diào)用的方法

    toString()一個(gè)會(huì)自動(dòng)調(diào)用的方法

    toString方法的作用是不用多說的了,這個(gè)JavaScript內(nèi)置方法還有一個(gè)特性是:在執(zhí)行一些特殊方法的時(shí)候,比如alert或innerHTML等方法,它將由腳本解析器自動(dòng)調(diào)用。
    2010-02-02
  • 使用Web?Component實(shí)現(xiàn)防篡改水印

    使用Web?Component實(shí)現(xiàn)防篡改水印

    Web?Component內(nèi)部有鉤子天然支持被篡改時(shí)被觸發(fā),用來防篡改非常方便,所以本文就將使用Web?Component實(shí)現(xiàn)防篡改水印,感興趣的小伙伴可以了解下
    2023-12-12
  • JavaScript實(shí)現(xiàn)刮刮樂效果

    JavaScript實(shí)現(xiàn)刮刮樂效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)刮刮樂效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • js?剪切、復(fù)制、粘貼功能實(shí)現(xiàn)

    js?剪切、復(fù)制、粘貼功能實(shí)現(xiàn)

    Navigator.clipboard?API可以用來訪問系統(tǒng)剪貼板,可以實(shí)現(xiàn)【剪切、復(fù)制、粘貼】功能。該?API?被設(shè)計(jì)用來取代使用?document.execCommand()?的剪貼板訪問方式,不兼容?IE
    2023-05-05
  • js實(shí)現(xiàn)限定區(qū)域范圍拖拉拽效果

    js實(shí)現(xiàn)限定區(qū)域范圍拖拉拽效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)限定區(qū)域范圍拖拉拽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 如何在selenium中使用js實(shí)現(xiàn)定位

    如何在selenium中使用js實(shí)現(xiàn)定位

    這篇文章主要介紹了如何在selenium中使用js實(shí)現(xiàn)定位,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • ECharts兩種動(dòng)畫效果完整代碼

    ECharts兩種動(dòng)畫效果完整代碼

    這篇文章主要給大家介紹了關(guān)于ECharts兩種動(dòng)畫效果的相關(guān)資料,在做項(xiàng)目時(shí)當(dāng)我們用到echarts圖表時(shí),大部分產(chǎn)品經(jīng)理都會(huì)要求我們給圖表加上一些動(dòng)畫效果,讓頁面看起來更加炫酷,需要的朋友可以參考下
    2023-07-07
  • xmlhttp緩存清除的2種解決方法

    xmlhttp緩存清除的2種解決方法

    這篇文章主要介紹了xmlhttp緩存清除的2種解決方法。需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2013-12-12
  • 詳解JavaScript的Date對(duì)象(制作簡易鐘表)

    詳解JavaScript的Date對(duì)象(制作簡易鐘表)

    這篇文章主要為大家詳細(xì)介紹了JavaScript的Date對(duì)象,和大家分享如何制作簡易鐘表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript實(shí)現(xiàn)前端倒計(jì)時(shí)效果

    JavaScript實(shí)現(xiàn)前端倒計(jì)時(shí)效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)前端倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-02-02

最新評(píng)論