symmetricDifference
Input two arrays arr1
and arr2
, and return their symmetric difference. Symmetric difference refers to the elements that are in either of the two sets but not in their intersection.
Accepts a getter
, which can be a field path of getByPath or a callback function, used to provide an identifier to distinguish elements.
Added in v0.0.1
Usage
ts
import { symmetricDifference } from 'parsnip-kit'
symmetricDifference([1, 2, 3, NaN], [1, 4, 8, NaN]) // [2, 3, 4, 8]
symmetricDifference(
[{ v: 1 }, { v: 2 }, { v: 3 }],
[{ v: 1 }, { v: 4 }, { v: 8 }],
'v'
) // [{ v: 2 }, { v: 3 }, { v: 4 }, { v: 8 }]
symmetricDifference(
[{ v: [1] }, { v: [2] }, { v: [3] }],
[{ v: [1] }, { v: [4] }, { v: [8] }],
'v[0]'
) // [{ v: [2] }, { v: [3] }, { v: [4] }, { v: [8] }]
symmetricDifference([1.1, 2.4, 3.9, 4.16], [1, 2, 3, 4, 5, 6], Math.floor) // [5, 6]
symmetricDifference([1.1, 2.4, 3.9, 4.16], [1, 2, 3, 4, 5, 6], (item: number, index: number, arr: number[]) => {
return Math.floor(item)
}) // [5, 6]
API
Type Parameter
Arg | Type | Description |
---|---|---|
T |
| Type of elements of array |
Arguments
Arg | Type | Optional | Default | Description |
---|---|---|---|---|
arr1 | T[] | false | undefined | Array for which the symmetric difference is to be calculated |
arr2 | T[] | false | undefined | Array for which the symmetric difference is to be calculated |
getter | string | ((item: T, index: number, arr: T[]) => any) | true | undefined | Provide an identifier to distinguish the elements |
Returns
Type |
---|
T[] |