2024-04-25 14:56:13 +03:00
|
|
|
# xorWith
|
|
|
|
|
2024-06-04 11:19:26 +03:00
|
|
|
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,
|
2024-04-25 14:56:13 +03:00
|
|
|
but not in their intersection.
|
|
|
|
|
|
|
|
## Signature
|
|
|
|
|
|
|
|
```typescript
|
|
|
|
function xorWith<T>(arr1: T[], arr2: T[], areElementsEqual: (item1: T, item2: T) => boolean): T[];
|
|
|
|
```
|
|
|
|
|
2024-06-04 11:19:26 +03:00
|
|
|
### Parameters
|
2024-04-25 14:56:13 +03:00
|
|
|
|
|
|
|
- `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
|
|
|
|
// Returns [{ id: 1 }, { id: 3 }]
|
|
|
|
xorWith([{ id: 1 }, { id: 2 }], [{ id: 2 }, { id: 3 }], (a, b) => a.id === b.id);
|
|
|
|
```
|