JavaScript 中的七個(gè)新 Set 方法:`union()`、`intersection()`,以及其他五個(gè)
我們坦誠(chéng)一點(diǎn):你可能對(duì) Set 并不怎么關(guān)心!至少直到現(xiàn)在……
Set 從 ES6 就已經(jīng)存在了,但通常它們只是用來確保列表中沒有重復(fù)項(xiàng)。
然而,隨著這7個(gè)即將推出的內(nèi)置 Set 方法,我們可能會(huì)發(fā)現(xiàn)自己更加頻繁地使用它們。
1. union()
Set 的新方法 union() 為我們提供了兩個(gè)集合中所有唯一的元素。
并且由于它是不可變的并返回副本,你可以無限鏈?zhǔn)秸{(diào)用它:
const setA = new Set([1, 2, 3]);
const setB = new Set([3, 4, 5]);
const unionSet = setA.union(setB); // Set {1, 2, 3, 4, 5}
2. intersection()
哪些元素同時(shí)存在于兩個(gè)集合中?
const setA = new Set([1, 2, 3]);
const setB = new Set([2, 3, 4]);
const intersectionSet = setA.intersection(setB); // Set {2, 3}
3. difference()
difference() 方法執(zhí)行 A - B,返回集合 A 中不在集合 B 中的所有元素:
const setA = new Set([1, 2, 3]);
const setB = new Set([2, 3, 4]);
const differenceSet = setA.difference(setB); // Set {1}
4. symmetricDifference()
正如 symmetric 所暗示的那樣,此方法雙向獲取集合差集。即 (A — B) U (B — A)。
所有只存在于其中一個(gè)集合中的元素:
const setA = new Set([1, 2, 3]);
const setB = new Set([3, 4, 5]);
const symmetricDifferenceSet = setA.symmetricDifference(setB); // Set {1, 2, 4, 5}
5. isSubsetOf()
其目的很明確:檢查一個(gè)集合的所有元素是否都在另一個(gè)集合中。
const setA = new Set([1, 2]);
const setB = new Set([1, 2, 3]);
const isSubset = setA.isSubsetOf(setB); // true
6. isSupersetOf()
檢查一個(gè)集合是否包含另一個(gè)集合中的所有元素:這與 isSubsetOf() 中交換兩個(gè)集合的作用相同:
const setA = new Set([1, 2, 3]);
const setB = new Set([1, 2]);
const isSuperset = setA.isSupersetOf(setB); // true
7. isDisjointFrom()
這些集合是否沒有任何共同元素?
const setA = new Set([1, 2, 3]);
const setB = new Set([4, 5, 6]);
const isDisjoint = setA.isDisjointFrom(setB); // true
現(xiàn)在就使用它們
通過 core-js polyfills:
npm install core-js
圖片
圖片
否則你可能會(huì)在 TypeScript 和 Node.js 中遇到錯(cuò)誤——因?yàn)樗鼈兩形幢徽郊{入 JavaScript 標(biāo)準(zhǔn)。
圖片
圖片
總結(jié)
圖片
以上就是我們介紹的 7 個(gè)新 Set 方法——再也不需要第三方庫(如 Lodash 的 _.intersection())了!