@utilslib/core/getArrayDifference
(A-B) 差集
getArrayDifference
函数签名
typescript
function getArrayDifference<T, K extends keyof T>(A: T[], B: T[], key?: K): T[]描述
(A-B) 差集
类型参数
| 参数名 | 约束 | 默认值 | 描述 |
|---|---|---|---|
T | - | - | - 数组元素类型 |
K | keyof T | - | - 用于判断的属性键名类型 |
参数
| 参数名 | 类型 | 可选 | 默认值 | 描述 |
|---|---|---|---|---|
A | T\[\] | 否 | - | - |
B | T\[\] | 否 | - | - |
key | K | 是 | - | - |
返回值
T\[\]
点击查看源码
js
/**
* (A-B) 差集
*
* @template T - 数组元素类型
* @template K - 用于判断的属性键名类型
* @param {T[]} A - 第一个数组
* @param {T[]} B - 第二个数组
* @param {K} [key] - 可选的用于判断的属性键名
* @returns {T[]} 差集数组
*/
export function getArrayDifference(A, B, key) {
if (key) {
const set = new Set(B.map((item) => item[key]));
return A.filter((item) => !set.has(item[key]));
}
return A.filter((item) => !B.includes(item));
}ts
/**
* (A-B) 差集
*
* @template T - 数组元素类型
* @template K - 用于判断的属性键名类型
* @param {T[]} A - 第一个数组
* @param {T[]} B - 第二个数组
* @param {K} [key] - 可选的用于判断的属性键名
* @returns {T[]} 差集数组
*/
export function getArrayDifference<T, K extends keyof T>(
A: T[],
B: T[],
key?: K,
): T[] {
if (key) {
const set = new Set(B.map((item) => item[key]));
return A.filter((item) => !set.has(item[key]));
}
return A.filter((item) => !B.includes(item));
}如有错误,请提交issue :::