溫馨提示×

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

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

ES6使用Set數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)數(shù)組的交集、并集、差集功能示例

發(fā)布時(shí)間:2020-08-20 17:17:38 來源:腳本之家 閱讀:162 作者:juzipchy 欄目:web開發(fā)

本文實(shí)例講述了ES6使用Set數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)數(shù)組的交集、并集、差集功能。分享給大家供大家參考,具體如下:

Set數(shù)據(jù)結(jié)構(gòu)是es6中新增的,它類似于數(shù)組,但是成員的值唯一,沒有重復(fù)值。

Set本身是一個(gè)數(shù)據(jù)結(jié)構(gòu),用來生成Set數(shù)據(jù)節(jié)后

Set數(shù)據(jù)結(jié)構(gòu)的實(shí)例有4種遍歷方法:

keys():返回一個(gè)鍵名的遍歷器
values():返回一個(gè)鍵值便利器
entries():返回一個(gè)鍵值對(duì)便利器
forEach():使用回調(diào)函數(shù)遍歷每個(gè)成員

由于Set數(shù)據(jù)結(jié)構(gòu)沒有鍵名,只有鍵值(或者說鍵名和鍵值是同一個(gè)值),所以keys和values方法的行為完全一致。

因此使用Set可以容易的實(shí)現(xiàn)交集、并集、差集

看看實(shí)現(xiàn)代碼:

let a=new Set([1,2,3]);
let b=new Set([4,3,2]);
//交集
let union= [...new Set([...a,...b])];
console.log(union);
//并集
let intersect= [...new Set([...a].filter(x=> b.has(x)))];
console.log(intersect);
//差集
let difference= [...new Set([...a].filter(x=> !b.has(x)))];
console.log(difference);

更多相關(guān)內(nèi)容可查看本站專題:《ECMAScript6(ES6)入門教程》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript字符與字符串操作技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《javascript面向?qū)ο笕腴T教程》

希望本文所述對(duì)大家基于ECMAScript的程序設(shè)計(jì)有所幫助。

向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