UNPKG

ut2

Version:

一个现代 JavaScript 实用工具库。[点击查看在线文档]。

33 lines (32 loc) 1.32 kB
import { IterateeParam } from './internals/types'; /** * 创建一个去重后的数组副本。只有第一次出现的元素才会被保留。如果传入迭代函数,会调用数组的每个元素以产生唯一性计算的标准。 * * `iteratee` 调用时会传入一个参数 `value`。 * * 默认使用了 [`SameValueZero`](https://tc39.es/ecma262/#sec-samevaluezero) 做等值比较。如果 `strictCheck=true` 将使用 [`SameValue`](https://tc39.es/ecma262/#sec-samevalue) 做等值比较。 * * @alias module:Array.uniq * @since 1.0.0 * @param {Array} array 要检查的数组。 * @param {Function | string | number | Symbol} [iteratee] 迭代函数,调用每个元素。 * @param {boolean} [strictCheck=false] 严格比较,区分 `0` `-0`。默认 `false`。 * @returns {Array} 去重后的新数组。 * @example * * uniq([2, 1, 2]); // [2, 1] * * uniq(['a', NaN, 2, 1, NaN, 'a', 1]); // ['a', NaN, 2, 1] * * uniq([{x: 1}, {x: 2}, {x: 1}], item=>item.x); // [{x: 1}, {x: 2}] * * // 迭代函数可以直接写入属性。 * uniq([{x: 1}, {x: 2}, {x: 1}], 'x'); // [{x: 1}, {x: 2}] * * uniq([-0, 0]); // [-0] * * uniq([-0, 0], undefined, true); // [-0, 0] * */ declare function uniq<T>(array: T[], iteratee?: IterateeParam<T>, strickCheck?: boolean): T[]; export default uniq;