亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解ES6中的Map與Set集合

 更新時(shí)間:2019年03月22日 09:13:44   作者:mynull  
這篇文章主要介紹了詳解ES6中的Map與Set集合,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

集合的概念以及和數(shù)組的區(qū)別

其實(shí)數(shù)組也是集合, 只不過(guò)數(shù)組的索引是數(shù)值類型.當(dāng)想用非數(shù)值類型作為索引時(shí), 數(shù)組就無(wú)法滿足需要了.

而 Map 集合可以保存多個(gè)鍵-值對(duì)(key-value),  Set 集合可以保存多個(gè)元素.

對(duì)Map 和 Set 一般不會(huì)逐一遍歷其中的元素. Map 一般用來(lái)存儲(chǔ)需要頻繁取用的數(shù)據(jù),  Set 一般用來(lái)判斷某個(gè)值是否存在其中.

ES 5 中對(duì) Map 和 Set 的模擬方法

在ES 5 中,沒(méi)有 Set和Map集合, 一般使用對(duì)象來(lái)模擬這兩種集合, 對(duì)象的屬性作為鍵(key),  以屬性值作為值(value),  即以 property: property-value 來(lái)模擬 key-value 的形式. 具體實(shí)現(xiàn)如下:

模擬 Map 的鍵值對(duì)集合:

// 創(chuàng)建一個(gè) Map 對(duì)象
var map = Object.create(null);

// 添加屬性和屬性值, 即 添加 key 和 value
map.key1 = 'value 1';
map.key2 = {};

// 取得 key 對(duì)應(yīng)的 value 
console.log(map.key1); // "value 1"
console.log(map.key2); // "Object {}"

模擬 Set :

// 創(chuàng)建一個(gè) Set 對(duì)象
var set = Object.create(null);

// 添加屬性和屬性值, 即 添加 key 并令其值為 true, 即表示這個(gè)key存在于集合中
set.key = true;

// 判斷 key 是否存在, 然后進(jìn)行下一步的操作
if(set.key) { ... }

用對(duì)象模擬這兩種集合的缺陷

由于對(duì)象中的屬性名必須是字符串, 如果傳入的不是字符串則會(huì)強(qiáng)制轉(zhuǎn)換成對(duì)應(yīng)的字符串類型

一般使用 if 語(yǔ)句來(lái)判斷一個(gè) key 是否存在于集合中,  當(dāng)這個(gè) key 對(duì)應(yīng)的 value 為 false 或者可以被強(qiáng)制轉(zhuǎn)換為 false 時(shí),  則 if 語(yǔ)句認(rèn)為這個(gè)key不存在.但是其實(shí)是存在的, 只不過(guò) value = false 而已.

ES6 中的 Map 和 Set 集合

下面正式來(lái)討論這兩種集合的特點(diǎn)

Map

Map 中存儲(chǔ)的是 key-value 形式的鍵值對(duì),  其中的 key 和 value 可以是任何類型的,  即對(duì)象也可以作為 key . 這比用對(duì)象來(lái)模擬的方式就靈活了很多

Map 的創(chuàng)建和初始化

可以用new Map()構(gòu)造函數(shù)來(lái)創(chuàng)建一個(gè)空的 Map

// 創(chuàng)建一個(gè)空的 Map 
let map = new Map();

也可以在 Map() 構(gòu)造函數(shù)中傳入一個(gè)數(shù)組來(lái)創(chuàng)建并初始化一個(gè) Map. 傳入的數(shù)組是二維數(shù)組, 其中的每一個(gè)子數(shù)組都有兩個(gè)元素,  前者會(huì)被作為 key,  后者會(huì)被作為 value,  這樣就形成了一個(gè) key-value 鍵值對(duì). 例如:

// 用數(shù)組來(lái)創(chuàng)建一個(gè) 非空的 Map 

let array = [ // 定義一個(gè)二維數(shù)組, 數(shù)組中的每子都有兩個(gè)元素
  ['key1' , 'value 1'],  // key 是 字符串 "key1", value 是字符串 "value 1"
  [{} , 10086] ,     // key 是個(gè)對(duì)象, value 是數(shù)值 10086
  [ 5, {} ]       // key 是個(gè)數(shù)值類型, value 是對(duì)象
];

let map = new Map(array); // 將數(shù)組傳入 Map 構(gòu)造函數(shù)中

Map 可用的 方法

  1. set(key, value): 向其中加入一個(gè)鍵值對(duì)
  2. get(key): 若不存在 key 則返回 undefined
  3. has(key):返回布爾值
  4. delete(key): 刪除成功則返回 true,  若key不存在或者刪除失敗會(huì)返回 false
  5. clear(): 將全部元素清除

size 屬性, 屬性值為 map 中鍵值對(duì)的個(gè)數(shù)

遍歷方法 forEach()

和數(shù)組的 forEach 方法類似, 回調(diào)函數(shù)中都包含3個(gè)參數(shù) 值, 鍵, 和 調(diào)用這個(gè)方法的 Map 集合本身

map.forEach(function(value, key, ownerMap){
  console.log(key, value); // 每對(duì)鍵和值
  console.log(ownerMap === map); // true
});

Set 集合

Set 和 Map 最大的區(qū)別是只有鍵 key 而沒(méi)有 value,  所以一般用來(lái)判斷某個(gè)元素(key)是否存在于其中.

創(chuàng)建和初始化方法, 和 Map 大同小異

既可以創(chuàng)建一個(gè)空 set 也可以用數(shù)組來(lái)初始化一個(gè)非空的set. 和 Map 不同的是, 數(shù)組是一維數(shù)組, 每個(gè)元素都會(huì)成為 set 的鍵.例如:

// 創(chuàng)建一個(gè)數(shù)組
let array = [1, 'str'];   // 一維數(shù)組

// 用數(shù)組來(lái)初始化 set
let set = new Set(array);

set 的方法

1、add(key): 往set添加一個(gè)元素,  如果傳入多個(gè)參數(shù), 則只會(huì)把第一個(gè)加入進(jìn)去

let set = new Set();
set.add(1, 2, 3);
console.log(set.has(1), set.has(2), set.has(3)); // true false false 可以看到只有第一個(gè)參數(shù)被加入進(jìn)了 set

2、has(key)
3、delete(key)
4、clear()

遍歷方法 forEach

和 Map 的 forEach 方法相似,  回調(diào)函數(shù)的參數(shù)也是3個(gè) (value,  key,  ownerSet). 按道理來(lái)說(shuō)因?yàn)?set 中只有 key 沒(méi)有 value,  那么會(huì)掉函數(shù)中不應(yīng)該存在 value 這個(gè)參數(shù), 那么為什么這個(gè) value 參數(shù)仍然存在呢?可能是因?yàn)?數(shù)組和 Map 的 forEach 方法的回調(diào)函數(shù)的參數(shù)都是這三個(gè),  如果對(duì)于 Set 而改變了參數(shù), 那么就會(huì)丟失了一致性. 這個(gè)理由......

那么既然沒(méi)有 value , 那么這個(gè)value的值是什么呢?答案是和key 一樣.我們可以把value和key 劃等號(hào)了.下面這段代碼可以驗(yàn)證這個(gè)說(shuō)法.

set.forEach(function(value, key, ownerSet){
  console.log(value === key, set === ownerSet);  // true true
});

WeakSet 和 WeakMap

這兩個(gè)集合比之前的兩個(gè)集合在名字之前都加上了 Weak,  這個(gè) Weak 可以直譯成弱,  這個(gè)弱指的是弱引用,  那么前面不帶Weak的 Set 和 Map就不弱, 就是強(qiáng)了,  這個(gè)強(qiáng)指的是強(qiáng)引用.

與 Set 和 Map 的區(qū)別

先說(shuō)表層的區(qū)別:

  • 弱版本集合的 key 只能是對(duì)象,  對(duì)于 value 的類型沒(méi)有限制.
  • 弱版本集合沒(méi)有 forEach 方法, 也沒(méi)有 for in 方法,  也不能用數(shù)組來(lái)初始化(會(huì)報(bào)錯(cuò)).
  • 弱版本可用的方法較少. WeakSet 只有 add, has, delete 方法可用; WeakMap 只有 set, has, get, delete 方法可用.

根本區(qū)別

弱版本的集合和它們對(duì)應(yīng)的強(qiáng)版本根本的區(qū)別在對(duì)于對(duì)象的引用的強(qiáng)弱上,  而對(duì)象指的是 key 位置的對(duì)象, 即以對(duì)象為key的情況.

強(qiáng)弱版本對(duì)于 key 是對(duì)象時(shí)的引用機(jī)制如下:

將對(duì)象設(shè)置為 key 時(shí), 就在集合中保存了這個(gè)對(duì)象的引用. 當(dāng)這個(gè)對(duì)象沒(méi)有其他引用了的時(shí)候, 即只有集合還引用著這個(gè)對(duì)象的時(shí)候, 弱類型的集合會(huì)放棄對(duì)這個(gè)對(duì)象的引用, 把這個(gè)對(duì)象從集合里移除, 不讓它繼續(xù)存在于集合中了, 有些“趕盡殺絕”的意思; 但是強(qiáng)類型的集合還會(huì)一直保存著對(duì)這個(gè)對(duì)象的引用, 就把它一直放在集合里.這就是 [WeakSet 和 WeakMap] 與 [Set 和 Map] 的根本區(qū)別.

要注意的是這個(gè)機(jī)制只作用于 key , 而 value 位置綁定的對(duì)象無(wú)論是否還存在別的引用, WeakMap 都不會(huì)放棄這個(gè)對(duì)象.只有這個(gè)位置的 key 綁定的對(duì)象沒(méi)有其他引用時(shí), 才會(huì)把 key 和 value 都放棄. 決定權(quán)在于 key 位置.

弱版本集合的主要用處

若版本集合可以用在需要生命周期管理的地方,例如保存對(duì)一個(gè) DOM 對(duì)象的引用, 如果一個(gè) DOM 對(duì)象使用完畢, 沒(méi)有其他的引用了, 那么它應(yīng)該被 垃圾回收,以免產(chǎn)生內(nèi)存泄漏,那么弱版本的集合就最適合用來(lái)保存這樣的對(duì)象了。

注意:四種集合都是有序的, 即元素被添加進(jìn)去的順序就是在內(nèi)部保存的順序. 對(duì)于用數(shù)組來(lái)初始化的集合也一樣, 按照在數(shù)組中的位置依次添加進(jìn)集合中.

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Javascript的表單驗(yàn)證-揭開正則表達(dá)式的面紗

    Javascript的表單驗(yàn)證-揭開正則表達(dá)式的面紗

    Javascript的表單驗(yàn)證-揭開正則表達(dá)式的面紗在本文重點(diǎn)介紹,感興趣的朋友一起學(xué)習(xí)吧
    2016-03-03
  • JS實(shí)現(xiàn)微信彈出搜索框 多條件查詢功能

    JS實(shí)現(xiàn)微信彈出搜索框 多條件查詢功能

    這篇文章主要介紹了JS實(shí)現(xiàn)微信彈出搜索框 多條件查詢功能的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-12-12
  • 判斷是否安裝flash player及當(dāng)前版本的JS代碼

    判斷是否安裝flash player及當(dāng)前版本的JS代碼

    本文為大家講述下如何使用jsJS判斷是否安裝flash player及版本,下面的處理代碼或許對(duì)大家有所幫助,感興趣的朋友可以參考下,希望對(duì)大家有所幫助
    2013-08-08
  • 詳解使用uni-app開發(fā)微信小程序之登錄模塊

    詳解使用uni-app開發(fā)微信小程序之登錄模塊

    這篇文章主要介紹了詳解使用uni-app開發(fā)微信小程序之登錄模塊,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-05-05
  • JavaScript變量類型以及變量作用域詳解

    JavaScript變量類型以及變量作用域詳解

    這篇文章主要為大家詳細(xì)介紹了JavaScript變量類型以及變量作用域的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Echarts實(shí)現(xiàn)點(diǎn)擊列表聯(lián)動(dòng)餅圖的示例代碼

    Echarts實(shí)現(xiàn)點(diǎn)擊列表聯(lián)動(dòng)餅圖的示例代碼

    本文主要介紹了Echarts實(shí)現(xiàn)點(diǎn)擊列表聯(lián)動(dòng)餅圖的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 微信小程序四種彈窗方式實(shí)例

    微信小程序四種彈窗方式實(shí)例

    微信小程序彈窗是小程序在需要提示用戶的時(shí)候,顯示的一種交互形式,下面這篇文章主要給大家介紹了關(guān)于微信小程序四種彈窗方式的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 利用JavaScript實(shí)現(xiàn)ISO周日歷

    利用JavaScript實(shí)現(xiàn)ISO周日歷

    周日歷是日常生活中不常用到的歷法系統(tǒng),一般用于政府、商務(wù)的會(huì)計(jì)年度或者學(xué)校教學(xué)日歷中。本文將利用JavaScript制作個(gè)簡(jiǎn)單的周日歷,感興趣的可嘗試一下
    2022-07-07
  • 微信小程序和百度的語(yǔ)音識(shí)別接口詳解

    微信小程序和百度的語(yǔ)音識(shí)別接口詳解

    這篇文章主要介紹了微信小程序和百度的語(yǔ)音識(shí)別接口詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)電子時(shí)鐘

    JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)電子時(shí)鐘

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)電子時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評(píng)論