成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

《深入理解ES6》筆記——Symbol和Symbol屬性(6)

heartFollower / 1088人閱讀

摘要:設置對象屬性只讀。提供了一個注冊機制,當你注冊之后,就能在全局共享注冊表里面的。的注冊表和對象表很像,都是結構,只不過這個是值。語法只有一個參數(shù),返回的是從注冊表獲取全局共享的注意如果要防止命名重復問題,可以加上前綴。

還記得對象Object嗎?

let obj = {
  a: 1
}

對象的格式:

Object {
    key: value
}

在ES5的時代,對象的key只能是字符串String類型。有人就想搞事,把key改成其他數(shù)據(jù)類型,這不是瞎折騰嗎?ES組織的大神們?yōu)榱藢Ω哆@類搞事的人,就指定了一個新的數(shù)據(jù)類型:Symbol。

原始數(shù)據(jù)類型

學習Symbol之前,讓我們回憶一下你曾經用過的原始數(shù)據(jù)類型,只有5個,別搞錯了。

null、undefined

是不是面試的時候有人問過你這兩者的區(qū)別?問這種問題的人很無聊,你要是和他當同事,真是受罪。

Number 數(shù)字類型

const a = 10
typeof a // number

String 字符串

const a = "haha"
typeof a // string

boolean 布爾型

const a = true, b = false
Symbol

Symbol到底長啥樣?又該怎么用呢?我們一起來探索一下。

在MDN文檔中,關于Symbol的說明是這樣的:

Symbol 是一種特殊的、不可變的數(shù)據(jù)類型,可以作為對象屬性的標識符使用。Symbol 對象是一個 symbol primitive data type 的隱式對象包裝器。

symbol 數(shù)據(jù)類型是一個原始數(shù)據(jù)類型。

Symbol的語法格式:

Symbol([description]) //description是可選的

創(chuàng)建一個Symbol:

看了Symbol的描述,不知道是什么鬼?長得像個函數(shù)。

我們開始按照語法創(chuàng)建一個Symbol來研究一下

const name = Symbol();
const name1 = Symbol("sym1");
console.log(name, name1) // Symbol() Symbol(sym1)

Symbol不能使用new

const name = new Symbol(); //不可以這樣做。
//Symbol is not a constructor

使用Symbol:

使用Number的時候,我們可以這樣寫:

const b = Number(10) // 10
//簡寫
const b = 10

同理,使用Symbol,我們可以這樣:

const name1 = Symbol("sym1"); // Symbol(sym1)

在所有使用可計算屬性名的地方,都能使用Symbol類型。比如在對象中的key。

const name = Symbol("name");
const obj = {
  [name]: "haha"
}
console.log(obj[name]) // haha

你還可以使用Object.defineProperty()和Object.defineProperties()方法。這2個方法是對象的方法,但是作為Symbol類型key,也不影響使用。

// 設置對象屬性只讀。
Object.defineProperty(obj, name, {writable: false})

這2個方法非常有用,在react源碼中,使用了大量的只讀屬性的對象。以下是從react源碼截取的一段代碼,設置了props對象只讀。但是react仍舊使用字符串作為key,并不用Symbol。

Object.defineProperty(props, "key", {
    get: warnAboutAccessingKey,
    configurable: true
  });
Symbol全局共享

Symbol有點特殊,在js文件中定義的Symbol,并不能在其他文件直接共享。

ES6提供了一個注冊機制,當你注冊Symbol之后,就能在全局共享注冊表里面的Symbol。Symbol的注冊表和對象表很像,都是key、value結構,只不過這個value是Symbol值。
(key, Symbol)
語法:

Symbol.for() //只有一個參數(shù)

還有一個方法是獲取注冊表的Symbol。

語法:

Symbol.keyFor() //只有一個參數(shù),返回的是key

從注冊表獲取全局共享的Symbol

let name = Symbol.for("name");
let name1 = Symbol.for("name1");
let name2 = Symbol.for("name2");

console.log(Symbol.keyFor(name)) // name
console.log(Symbol.keyFor(name1)) // name1
console.log(Symbol.keyFor(name2)) // name2

注意:如果要防止Symbol命名重復問題,可以加上前綴。如:hyy.name

Symbol與類型強制轉換

JavaScript中的類型可以自動轉換。比如Number轉換成字符串。

let a = 1;
console.log(typeof a); // number
console.log(a + " haha") // "1haha"

但是注意了,Symbol不支持這種轉換。Symbol就是這么拽??!

let a = Symbol("a");
console.log(typeof a);
console.log(a + " haha") // Cannot convert a Symbol value to a string
Symbol檢索

在對象中獲取字符串的key時,可以使用Object.keys()或Object.getOwnPropertyNames()方法獲取key,但是使用Symbol做key是,你就只能使用ES6新增的方法來獲取了。

let a = Symbol("a");
let b = Symbol("b");

let obj = {
  [a]: "123",
  [b]: 45
}

const symbolsKey = Object.getOwnPropertySymbols(obj);

for(let value of symbolsKey) {
  console.log(obj[value]) 
}
//"123"
//45
總結

Symbol還提供了多個方法給開發(fā)者使用,我們不再一一研究每個方法的用途,你想要了解全面可以查看 Symbol MDN文檔

我們只需要知道Symbol如何定義,如何在全局共享,如果在對象中替代key即可應付基本的開發(fā)需求了。

最后再回顧一下Symbol是什么:Symbol是JavaScript的原始數(shù)據(jù)類型,一個全新的數(shù)據(jù)類型,和對象、數(shù)字、字符串等完全不一樣,它必須通過Symbol()創(chuàng)建。它的使用看上面的詳細介紹。

=> 返回文章目錄

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/84117.html

相關文章

  • 深入理解ES6筆記(六)SymbolSymbol屬性

    摘要:先搜索全局符號注冊表,如果已有,則返回這個已存在的符號值否則,會創(chuàng)建一個新的符號值,并使用該鍵值將其記錄到全局符號注冊表中,然后返回這個新的符號值。 主要知識點:創(chuàng)建符號值、使用符號值、共享符號值、符號值轉換。檢索符號值屬性以及知名符號 showImg(https://segmentfault.com/img/bVbfWhK?w=1203&h=633); 《深入理解ES6》筆記 目錄 ...

    crossea 評論0 收藏0
  • 深入理解ES6筆記——迭代器(Iterator)生成器(Generator)(8)

    摘要:迭代器是一種特殊對象,每一個迭代器對象都有一個,該方法返回一個對象,包括和屬性。默認情況下定義的對象是不可迭代的,但是可以通過創(chuàng)建迭代器。在迭代器中拋出錯誤不再執(zhí)行生成器返回語句生成器中添加表示退出操作。迭代器是一個對象。 迭代器(Iterator) ES5實現(xiàn)迭代器 迭代器是什么?遇到這種新的概念,莫慌張。 迭代器是一種特殊對象,每一個迭代器對象都有一個next(),該方法返回一個對...

    AndroidTraveler 評論0 收藏0
  • 深入理解ES6筆記——Set集合與Map集合(7)

    摘要:常被用來檢查對象中是否存在某個鍵名,集合常被用來獲取已存的信息。返回一個布爾值,表示該值在中存在與否。集合存放對象的弱引用,當該對象的其他強引用被清除時,集合中的弱引用也會自動被垃圾回收機制回收,追蹤成組的對象是該集合最好的使用方式。 Map和Set都叫做集合,但是他們也有所不同。Set常被用來檢查對象中是否存在某個鍵名,Map集合常被用來獲取已存的信息。 Set Set是有序列表,含...

    Charlie_Jade 評論0 收藏0

發(fā)表評論

0條評論

heartFollower

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<