摘要:設置對象屬性只讀。提供了一個注冊機制,當你注冊之后,就能在全局共享注冊表里面的。的注冊表和對象表很像,都是結構,只不過這個是值。語法只有一個參數(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 = falseSymbol
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 stringSymbol檢索
在對象中獲取字符串的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
摘要:先搜索全局符號注冊表,如果已有,則返回這個已存在的符號值否則,會創(chuàng)建一個新的符號值,并使用該鍵值將其記錄到全局符號注冊表中,然后返回這個新的符號值。 主要知識點:創(chuàng)建符號值、使用符號值、共享符號值、符號值轉換。檢索符號值屬性以及知名符號 showImg(https://segmentfault.com/img/bVbfWhK?w=1203&h=633); 《深入理解ES6》筆記 目錄 ...
摘要:迭代器是一種特殊對象,每一個迭代器對象都有一個,該方法返回一個對象,包括和屬性。默認情況下定義的對象是不可迭代的,但是可以通過創(chuàng)建迭代器。在迭代器中拋出錯誤不再執(zhí)行生成器返回語句生成器中添加表示退出操作。迭代器是一個對象。 迭代器(Iterator) ES5實現(xiàn)迭代器 迭代器是什么?遇到這種新的概念,莫慌張。 迭代器是一種特殊對象,每一個迭代器對象都有一個next(),該方法返回一個對...
摘要:常被用來檢查對象中是否存在某個鍵名,集合常被用來獲取已存的信息。返回一個布爾值,表示該值在中存在與否。集合存放對象的弱引用,當該對象的其他強引用被清除時,集合中的弱引用也會自動被垃圾回收機制回收,追蹤成組的對象是該集合最好的使用方式。 Map和Set都叫做集合,但是他們也有所不同。Set常被用來檢查對象中是否存在某個鍵名,Map集合常被用來獲取已存的信息。 Set Set是有序列表,含...
閱讀 964·2023-04-25 23:50
閱讀 1994·2021-11-19 09:40
閱讀 608·2019-08-30 13:50
閱讀 2736·2019-08-29 17:11
閱讀 1051·2019-08-29 16:37
閱讀 2996·2019-08-29 12:54
閱讀 2803·2019-08-28 18:17
閱讀 2647·2019-08-26 16:55