Інша відповідь буде добре працювати; ось ще одна альтернатива.
// Create function to check if an element is in a specified set.
function isIn(s) { return elt => s.has(elt); }
// Check if one set contains another (all members of s2 are in s1).
function contains(s1, s2) { return [...s2] . every(isIn(s1)); }
// Set equality: a contains b, and b contains a
function eqSet(a, b) { return contains(a, b) && contains(b, a); }
// Alternative, check size first
function eqSet(a, b) { return a.size === b.size && contains(a, b); }
Однак майте на увазі, що це не робить глибокого порівняння рівності. Так
eqSet(Set([{ a: 1 }], Set([{ a: 1 }])
повернеться помилковим. Якщо вищевказані два набори вважати рівними, нам потрібно повторити обидва набори, роблячи глибокі порівняння якості кожного елемента. Ми обумовлюємо існування deepEqual
розпорядку. Тоді логіка була б
// Find a member in "s" deeply equal to some value
function findDeepEqual(s, v) { return [...s] . find(m => deepEqual(v, m)); }
// See if sets s1 and s1 are deeply equal. DESTROYS s2.
function eqSetDeep(s1, s2) {
return [...s1] . every(a1 => {
var m1 = findDeepEqual(s2, a1);
if (m1) { s2.delete(m1); return true; }
}) && !s2.size;
}
Що це робить: для кожного члена s1 шукайте глибоко рівного члена s2. Якщо він знайдеться, видаліть його, щоб він більше не міг використовуватись. Два набори глибоко рівні, якщо всі елементи s1 знайдені в s2, і s2 вичерпано. Неперевірений.
Це може бути вам корисним: http://www.2ality.com/2015/01/es6-set-operations.html .
===
є для ціннісної рівності, а не об'єктної рівності.