Skip to content

xorWith

Computes the symmetric difference between two arrays using a custom equality function. The symmetric difference is the set of elements which are in either of the arrays, but not in their intersection.

Signature

typescript
function xorWith<T>(arr1: T[], arr2: T[], areElementsEqual: (item1: T, item2: T) => boolean): T[];

Parameters

  • arr1 (T[]): The first array.
  • arr2 (T[]): The second array.
  • areElementsEqual ((item1: T, item2: T) => boolean): The custom equality function to compare elements.

Returns

(T[]): An array containing the elements that are present in either arr1 or arr2 but not in both, based on the custom equality function.

Examples

typescript
import { 
xorWith
} from 'js-utils-es/array';
// Returns [{ id: 1 }, { id: 3 }]
xorWith
([{
id
: 1 }, {
id
: 2 }], [{
id
: 2 }, {
id
: 3 }], (
a
,
b
) =>
a
.
id
===
b
.
id
);

Source

SourceDocsTest Case

Contributors

Changelog

No recent changes

Made with ❤️