Skip to content

difference(Lodash 兼容性)

使用 es-toolkitdifference

difference 函数由于处理 nullundefined、多个数组参数处理而变得复杂。

请使用 es-toolkit 中更快、更现代的 difference

从第一个数组中排除其他数组的值,求差集。

typescript
const result = difference(arr, ...values);

参考

difference(arr, ...values)

当你想要从第一个数组中删除所有包含在其余数组中的值时,使用 difference。顺序保持第一个数组的顺序。

typescript
import { difference } from 'es-toolkit/compat';

// 基本用法
const array1 = [1, 2, 3, 4, 5];
const array2 = [2, 4];
const array3 = [5, 6];
difference(array1, array2, array3);
// Returns: [1, 3]

// 字符串数组
difference(['a', 'b', 'c'], ['b'], ['c', 'd']);
// Returns: ['a']

// 处理重复值
difference([1, 2, 2, 3], [2]);
// Returns: [1, 3]

也可以处理空数组或空差集。

typescript
import { difference } from 'es-toolkit/compat';

// 与空数组的差集
difference([1, 2, 3], []);
// Returns: [1, 2, 3]

// 所有值都被排除的情况
difference([1, 2, 3], [1, 2, 3]);
// Returns: []

// 没有重叠值的情况
difference([1, 2], [3, 4]);
// Returns: [1, 2]

nullundefined 数组被视为空数组。

typescript
import { difference } from 'es-toolkit/compat';

difference(null, [1, 2]);
// Returns: []

difference(undefined, [1, 2]);
// Returns: []

difference([1, 2, 3], null, undefined);
// Returns: [1, 2, 3] (null和undefined被忽略)

也支持类数组对象。

typescript
import { difference } from 'es-toolkit/compat';

// 类数组对象
const arrayLike1 = { 0: 1, 1: 2, 2: 3, length: 3 };
const arrayLike2 = { 0: 2, 1: 4, length: 2 };
difference(arrayLike1, arrayLike2);
// Returns: [1, 3]

参数

  • arr (ArrayLike<T> | null | undefined): 求差集的基准数组。
  • values (...ArrayLike<T>[]): 包含要排除的值的数组。

返回值

(T[]): 返回从第一个数组中排除其他数组值的新数组。

采用 MIT 许可证发布。