亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

ES6中Symbol、Set和Map用法詳解

2024-05-06 16:54:21
字體:
來源:轉載
供稿:網友

本文實例講述了ES6中Symbol、Set和Map用法。分享給大家供大家參考,具體如下:

Symbol

1.Symbol 是 ES6 引入了一種新的原始數據類型,表示獨一無二的值。它是 JavaScript 語言的第七種數據類型,前六種分別是:undefined、null、布爾值(Boolean)、字符串(String)、數值(Number)、對象(Object);

2.Symbol 值通過Symbol函數生成,可以作為對象的屬性名使用,保證不會與其他屬性名產生沖突;

let s = Symbol();typeof s // symbol

ps:上面代碼表示創建一個Symbol變量,值得注意的是,Symbol函數前不能使用new命令,否則會報錯,也就是說Symbol 是一個原始類型的值,不是對象,也不能添加屬性;

3.Symbol函數可以接受一個字符串作為參數,表示對 Symbol 實例的描述,主要用于區分不同的 Symbol 變量;

let s1 = Symbol('a');let s2 = Symbol('b');s1.toString() // 'Symbol(a)'s2.toString() // 'Symbol(b)'

ps:Symbol函數的參數只是表示對當前 Symbol 值的描述,因此相同參數的Symbol函數的返回值是不相等的

let s1 = Symbol('a');let s2 = Symbol('a');s1 === s2 //false

4.Symbol 值不能與其他類型的值進行運算,但可以轉為布爾值,但是不能轉為數值;

let s = Symbol();s + '2'    // Cannot convert a Symbol value to a stringBoolean(s)  // true!s      // false

5.用于對象的屬性名,可以保證不會出現同名的屬性,對于一個對象由多個模塊構成的情況非常有用,能防止某一個鍵被不小心改寫或覆蓋;值得注意的是,Symbol 值作為對象屬性名時,不能用點運算符,因為點運算符后面是一個字符串;

let s = Symbol();let obj = {};obj[s] = 'hello world';//或者let obj = {  [s] : 'hello world'}obj.s  // undefinedobj[s] // hello world

6.Symbol 作為屬性名,不會被常規方法遍歷得到,即該屬性不會出現在for...in、for...of循環中,也不會被Object.keys()、Object.getOwnPropertyNames()、JSON.stringify()返回,但是,它并不是私有屬性,可以使用 Object.getOwnPropertySymbols 方法,可以獲取指定對象的所有 Symbol 屬性名;

var obj = {};var a = Symbol('a');var b = Symbol('b');obj[a] = 'Hello';obj[b] = 'World';obj.c = 'Mine';for( let key in obj ){  console.log(key)     // c}var objectSymbols = Object.getOwnPropertySymbols(obj);console.log(objectSymbols) // [Symbol(a), Symbol(b)]

7.Symbol.for方法接受一個字符串作為參數,然后搜索有沒有以該參數作為名稱的Symbol值。如果有,就返回這個Symbol值,否則就新建并返回一個以該字符串為名稱的Symbol值;它與Symbol()不同的是,Symbol.for()不會每次調用就返回一個新的 Symbol 類型的值,而是會先檢查給定的key是否已經存在,如果不存在才會新建一個值,而 Symbol()每次都會返回3不同的Symbol值;

Symbol.for("name") === Symbol.for("name")// trueSymbol("name") === Symbol("name")// false

8.Symbol.keyFor方法返回一個已登記的 Symbol 類型值的key,而Symbol()寫法是沒有登記機制的;

var s1 = Symbol.for("name");Symbol.keyFor(s1) // "name"var s2 = Symbol("name");Symbol.keyFor(s2) // undefined

ps:Symbol.for為Symbol值登記的名字,是全局環境的,可以在不同的 iframe 或 service worker 中取到同一個值

Set 和 Map

1.ES6 提供了新的數據結構 Set。它類似于數組,但是成員的值都是唯一的,沒有重復的值,它 本身是一個構造函數,用來生成 Set 數據結構。

let s = new Set([1,2,3,4,5,2,2,3,5]);s // [1,2,3,4,5]

2.可以使用add(key)方法可以添加元素到Set中,可以重復添加,但不會有效果,值得注意的是向Set加入值的時候,不會發生類型轉換,即 5 和 "5" 是兩個不同的值,但在 Set 內部,兩個NaN是相等

let s = new Set([1,2,3]);s.add(4)  //[1,2,3,4]s.add(4)  //[1,2,3,4]s.add(5)  //[1,2,3,4,5]s.add('5') //[1,2,3,4,5,"5"]s.add(NaN) //[1,2,3,4,5,"5",NaN]s.add(NaN) //[1,2,3,4,5,"5",NaN]

3.可以利用Set數據不重復的特性,提供一種新的數組去重方法

// 去除數組的重復成員[...new Set(array)][...new Set([1,2,2,3,3,4,5,5])] //[1,2,3,4,5]

4.Set常見的操作方法有:

add(value):添加某個值,返回Set結構本身。
delete(value):刪除某個值,返回一個布爾值,表示刪除是否成功。
has(value):返回一個布爾值,表示該值是否為Set的成員。

clear():清除所有成員,沒有返回值。

s.add(1).add(2).add(2);// 注意2被加入了兩次s.size // 2s.has(1) // trues.has(2) // trues.has(3) // falses.delete(2);s.has(2) // false

5.Set 結構的實例有四個遍歷方法,可以用于遍歷成員。

keys():返回鍵名的遍歷器
values():返回鍵值的遍歷器
entries():返回鍵值對的遍歷器

forEach():使用回調函數遍歷每個成員
需要特別指出的是,Set的遍歷順序就是插入順序。這個特性有時非常有用,比如使用Set保存一個回調函數列表,調用時就能保證按照添加順序調用。

let set = new Set(['red', 'green', 'blue']);for (let item of set.keys()) {console.log(item);}// red// green// bluefor (let item of set.values()) {console.log(item);}// red// green// bluefor (let item of set.entries()) {console.log(item);}// ["red", "red"]// ["green", "green"]// ["blue", "blue"]

6.ES6 提供了 Map 數據結構,它類似于對象,也是鍵值對的集合,但是“鍵”的范圍不限于字符串,各種類型的值(包括對象)都可以當作鍵,是一種更完善的 Hash 結構實現。如果你需要“鍵值對”的數據結構,Map 比 Object 更合適;

7.Map常見的操作方法有:

set(key,val):添加某個值,返回Map結構本身。
get(key):     讀取某個鍵,如果該鍵未知,則返回undefined
delete(key):  刪除某個鍵,返回一個布爾值,表示刪除是否成功。
has(key):     返回一個布爾值,表示該值是否為Map的鍵。
clear() :      清除所有成員,沒有返回值。

const m = new Map();const o = { str : 'Hello World'};m.set(o, 'content')m.get(o) // "content"m.has(o) // truem.delete(o) // truem.has(o) // false

8.只有對同一個對象的引用,Map 結構才將其視為同一個鍵

const map = new Map();const k1 = ['a'];const k2 = ['a'];map.set(k1, 111).set(k2, 222);map.get(k1) // 111map.get(k2) // 222

上面例子表明,Map 的鍵實際上是跟內存地址綁定的,只要內存地址不一樣,就視為兩個鍵,因為 k1 和 k2 是兩個不同的對象,放在不同的內存地址中,所以Map視為不同的鍵

9.Map 結構原生提供三個遍歷器生成函數和一個遍歷方法。

keys():返回鍵名的遍歷器。
values():返回鍵值的遍歷器。
entries():返回所有成員的遍歷器。
forEach():遍歷 Map 的所有成員。

ps:Map 的遍歷順序就是插入順序,這里就不示例了,大家自己動手實踐一下。

10.可以使用擴展運算符(...)將Map轉換為數組,反過來,將數組傳入 Map 構造函數,就可以轉為 Map了

//Map轉數組const map = new Map();map.set('name' , 'hello').set({},'world');[...map] //[["name","hello"],[{},"world"]]//數組轉Mapconst map = new Map([["name","hello"],[{},"world"]]);map // {"name" => "hello", Object {} => "world"}

 

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品一区二区三区免费视频| 精品久久久免费| 国产精品久久久久久久久粉嫩av| 国产国语videosex另类| 夜夜狂射影院欧美极品| 麻豆国产精品va在线观看不卡| 国产精品视频一区二区高潮| 久久精品99久久香蕉国产色戒| 亚洲人成电影网站色| 日本aⅴ大伊香蕉精品视频| 亚洲天堂网在线观看| 久久影视电视剧免费网站| 韩剧1988免费观看全集| 日韩不卡中文字幕| 91国内精品久久| 欧美日韩中文字幕在线| 国产欧美精品在线播放| 亚洲人成电影在线观看天堂色| 51精品国产黑色丝袜高跟鞋| 国产在线视频不卡| 国产成人亚洲精品| 亚洲精品日韩欧美| 日本亚洲欧美成人| 精品久久久久久国产91| 久久久久久久久久国产精品| 成人激情视频在线播放| 亚洲国产精品久久久久秋霞不卡| 久久久噜噜噜久噜久久| 亚洲最新av网址| 深夜福利亚洲导航| 欧美大成色www永久网站婷| 亚洲成色999久久网站| 欧美限制级电影在线观看| 69精品小视频| 亚洲一区美女视频在线观看免费| 久久国产精品免费视频| 韩剧1988在线观看免费完整版| 精品网站999www| 日韩在线播放一区| 国产精品爽黄69| 亚洲精品女av网站| 欧美精品一二区| 国产男人精品视频| 日韩视频免费观看| 欧美午夜精品久久久久久浪潮| 中文字幕在线观看日韩| 国产精品一区二区在线| 日韩欧亚中文在线| 国产精品亚洲激情| 欧美日韩亚洲一区二区三区| 国产精品国产亚洲伊人久久| 亚洲人a成www在线影院| 免费av在线一区| 日韩www在线| 精品亚洲精品福利线在观看| 91亚洲精品一区| 海角国产乱辈乱精品视频| 日韩免费观看av| 久久久国产精品视频| 国产日韩欧美在线| 国产精品久久一区主播| 亚洲乱码一区二区| 久久久噜噜噜久噜久久| 日韩免费在线播放| 国产精品久久久久久久久借妻| 91久久久久久久一区二区| 亚洲电影在线观看| 国产成人精品一区二区在线| 久久九九热免费视频| 欧美性猛交xxxx乱大交| 亚洲欧美中文字幕| 色青青草原桃花久久综合| 国内精品国产三级国产在线专| 欧美成人精品激情在线观看| 国产91成人video| 日本免费久久高清视频| 中文字幕最新精品| 91久久精品日日躁夜夜躁国产| 精品国产老师黑色丝袜高跟鞋| 国产91精品青草社区| 欧美精品videos性欧美| 日韩欧美国产黄色| 国产精品青青在线观看爽香蕉| 国产精品视频专区| 欧美精品成人91久久久久久久| 亚洲综合国产精品| 丰满岳妇乱一区二区三区| 91精品国产综合久久久久久久久| 国产亚洲日本欧美韩国| 欧美视频中文在线看| 操日韩av在线电影| 国产精品av在线| 在线亚洲欧美视频| 欧美性受xxx| 亚洲一区二区中文字幕| 黑人精品xxx一区| 亚洲色图综合久久| 欧美国产视频日韩| 久久伊人色综合| 欧美日韩一区二区在线播放| 欧美夫妻性生活xx| 国产日韩综合一区二区性色av| 亚洲人成77777在线观看网| 九九视频这里只有精品| 疯狂欧美牲乱大交777| 性欧美xxxx交| 欧美小视频在线| 国产精品久久久久久久久久久不卡| 2020欧美日韩在线视频| 亚洲精品一区久久久久久| 亚洲欧美中文日韩v在线观看| x99av成人免费| 26uuu另类亚洲欧美日本老年| 青青久久av北条麻妃海外网| 亚洲黄页网在线观看| 日韩福利视频在线观看| 日本亚洲欧美成人| 成人在线视频网| 欧美亚洲视频一区二区| 日韩精品欧美国产精品忘忧草| 国产日韩精品在线观看| 九色成人免费视频| 日韩69视频在线观看| 国产午夜精品全部视频在线播放| 日韩中文在线中文网在线观看| 久久久精品免费视频| 亚洲国产精彩中文乱码av| 色偷偷噜噜噜亚洲男人| 欧美性黄网官网| 亚洲图片在线综合| 中文国产成人精品| 亚洲精品二三区| 欧美日韩精品在线视频| 亚洲国产天堂久久国产91| 欧美在线视频播放| 国产mv久久久| 久久在线精品视频| 亚洲人高潮女人毛茸茸| 97精品国产91久久久久久| 国产精品成人一区二区| 中文字幕日韩精品有码视频| 国产精品女视频| 日韩精品一区二区视频| 久久久国产精品一区| 欧美日韩一区二区免费在线观看| 日韩亚洲欧美中文在线| 国产成人精品视| 国产午夜一区二区| 亚洲欧洲午夜一线一品| 91精品视频在线播放| 2019中文字幕在线| 国产不卡视频在线| 欧美日韩亚洲精品内裤| 日本精品性网站在线观看| 一区二区三区无码高清视频| 91在线视频导航| 色偷偷91综合久久噜噜| 午夜免费在线观看精品视频| 精品少妇一区二区30p| 欧美性xxxxxxxxx| 日韩高清a**址| www.日韩视频| 精品一区二区电影| 懂色av中文一区二区三区天美|