步驟:1、將兩個陣列分別轉換為set類型,語法「newA=new Set(a);newB=new Set(b);」;2、利用has()和filter()求差集,語法“new Set([...newA].filter(x =>!newB.has(x)))”,差集元素會被包含在一個set集合中返回;3、利用Array .from將集合轉為陣列類型,語法「Array.from(集合)」。
本教學操作環境:windows7系統、ECMAScript 6版、Dell G3電腦。
找出2個陣列中不同項,就是取得兩個陣列的差集。
在es6中,可以藉助set物件的has()方法來求兩個陣列的差集。
實作步驟:
步驟1、將兩個陣列分別轉為set類型
let a=[1, 2, 3]; let b=[3, 5, 2]; newA = new Set(a); newB = new Set(b);
步驟2:求差集
利用set物件的has() 方法來配合陣列的filter()來求兩個陣列的差集。
Set has() 方法指示 Set 物件是否包含指定的值;如果指定的值存在,則傳回真,否則傳回假。
而filter()方法用於過濾數組,傳回符合條件(為真)的元素。
實作程式碼
let a=[1, 2, 3]; let b=[3, 5, 2]; newA = new Set(a); newB = new Set(b); console.log(newA); console.log(newB); let differenceABSet = new Set([...newA].filter(x => !newB.has(x))); console.log("差集为:"); console.log(differenceABSet);
#可以看出此時,差集元素被包含在一個set集合中傳回,我們可以將其轉為數組類型。
步驟3:利用Array.from方法將集合轉換為陣列型別
let a=[1, 2, 3]; let b=[3, 5, 2]; newA = new Set(a); newB = new Set(b); console.log(newA); console.log(newB); let differenceABSet = Array.from(new Set([...newA].filter(x => !newB.has(x)))); console.log("差集为:"); console.log(differenceABSet);
說明:Array.from方法用於將兩類物件轉為真正的陣列:類似陣列的物件(array-like object)和可遍歷(iterable)的物件(包括ES6 新增的資料結構Set 和Map)。
擴展知識:求並集/交集
let a = new Set([1, 2, 3]); let b = new Set([3, 5, 2]); // 并集 let unionSet = new Set([...a, ...b]); //[1,2,3,5] // ab交集 let intersectionSet = new Set([...a].filter(x => b.has(x)));
【相關推薦:javascript影片教學、web前端】
以上是es6怎麼找出2個數組中不同項的詳細內容。更多資訊請關注PHP中文網其他相關文章!