溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ES6新數(shù)據(jù)結(jié)構(gòu)Set與WeakSet怎么用

發(fā)布時(shí)間:2021-08-04 09:49:20 來(lái)源:億速云 閱讀:122 作者:小新 欄目:web開發(fā)

這篇文章主要介紹ES6新數(shù)據(jù)結(jié)構(gòu)Set與WeakSet怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

新數(shù)據(jù)結(jié)構(gòu)Set與WeakSet

1. Set

Set類似于數(shù)據(jù),但是成員值都是唯一的。生成Set的方式如下。

var s = new Set();
[1,1,3,3,5,5].map( x => s.add(x) );
console.log(s); //Set {1, 3, 5}

沒有重復(fù)值喲,如果面試官再讓你編寫數(shù)組去重的函數(shù)是不是簡(jiǎn)單多了。或者你可以這樣寫。

var set = new Set( [2,2,4,4,6,6] ); //Set {2, 4, 6}
console.log(set);

其實(shí),Set作為構(gòu)造函數(shù)使用時(shí),接受的參數(shù)不僅可以是數(shù)組,任何類數(shù)組的對(duì)象也可以。Set的成員可以是對(duì)象,只是每個(gè)對(duì)象唯一。

那么,我們?nèi)绾尾倏vSet呢。

s.add(val); //為s添加val,返回s
s.delete(val); //刪除val,返回表示成功與否的布爾值
s.has(val); //返回表示s是否擁有成員val的布爾值
s.clear(); //清除所有成員

map與filter方法可以作用于數(shù)組,也可以用于Set(見第一個(gè)代碼塊)。

那么,我們?nèi)绾伪闅vSet呢。

依然是 keys() , values() , entries() , forEach() . 舉例如下(默認(rèn)情況下Set的鍵與值相同):

var s = new Set();
var ul = document.getElementsByTagName('ul');
[1,1,3,3,5,5].map( x => s.add(x) );
for ( let key of s.keys() ){
  console.log(key); //1 , 3, 5
}
for ( let val of s.values() ){
  console.log(val); //1, 3,5
}
for ( let item of s.entries() ){
  console.log(item[0],item[1]); // 1 1 , 3 3, 5 5
}
for ( let [key,val] of s.entries() ){
  console.log(key,val); // 1 1 , 3 3, 5 5
}
s.forEach( function( val , key , ul ){
  console.log( this ); //ul
  console.log( val , key);
} , ul );

可以使用...擴(kuò)展操作符把Set轉(zhuǎn)換成數(shù)組。

2.WeakSet

WeakSet與Set類似,也是不重復(fù)的集合。區(qū)別在于:WeakSet的成員只能是對(duì)象;WeakSet中的對(duì)象是弱引用,即垃圾回收機(jī)制不考慮WeakSet對(duì)該對(duì)象的引用。當(dāng)其他變量不再引用某對(duì)象,其將被垃圾回收機(jī)制回收,哪怕這個(gè)對(duì)象被WeakSet引用。這意味著,WeakSet的成員是無(wú)法被引用的,無(wú)法遍歷WeakSet。WeakSet只有add、delete和has三個(gè)方法。注意:WeakSet沒有size屬性,也沒有forEach方法。

對(duì)于WeakSet不能被遍歷,可以這樣解釋。因?yàn)槠涑蓡T都是弱引用,隨時(shí)可能消失,遍歷機(jī)制無(wú)法保證其成員一直存在。

那你可能問,WeakSet用來(lái)做什么,答,儲(chǔ)存DOM節(jié)點(diǎn),這樣移除DOM時(shí)就可以不用擔(dān)心內(nèi)存泄漏了。

以上是“ES6新數(shù)據(jù)結(jié)構(gòu)Set與WeakSet怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI