_.partition(collection, [predicate=_.identity])
83
_.partition(collection, [predicate=_.identity])
_.partition将一个集合的元素分成两组数组,然后返回这两组数组组成的数组。第一个数组是遍历后predicate返回true的所有元素,第二个数组是遍历后predicate返回false的所有元素
参数
collection (Array|Object): 需要遍历的集合
[predicate=_.identity] (Function): 集合每一个元素需要调用的方法
返回值
(Array): 返回分好组的数组
例子
var users = [ { 'user': 'barney', 'age': 36, 'active': false }, { 'user': 'fred', 'age': 40, 'active': true }, { 'user': 'pebbles', 'age': 1, 'active': false } ]; _.partition(users, function(o) { return o.active; }); // => objects for [['fred'], ['barney', 'pebbles']] // The `_.matches` iteratee shorthand. _.partition(users, { 'age': 1, 'active': false }); // => objects for [['pebbles'], ['barney', 'fred']] // The `_.matchesProperty` iteratee shorthand. _.partition(users, ['active', false]); // => objects for [['barney', 'pebbles'], ['fred']] // The `_.property` iteratee shorthand. _.partition(users, 'active'); // => objects for [['fred'], ['barney', 'pebbles']]
源代码:
省略iteratee的处理,想看iteratee的处理看这里,https://www.cnblogs.com/hahazexia/p/9901435.html
import reduce from './reduce.js' /** * Creates an array of elements split into two groups, the first of which * contains elements `predicate` returns truthy for, the second of which * contains elements `predicate` returns falsey for. The predicate is * invoked with one argument: (value). * * @since 3.0.0 * @category Collection * @param {Array|Object} collection The collection to iterate over. * @param {Function} predicate The function invoked per iteration. * @returns {Array} Returns the array of grouped elements. * @see groupBy, keyBy * @example * * const users = [ * { 'user': 'barney', 'age': 36, 'active': false }, * { 'user': 'fred', 'age': 40, 'active': true }, * { 'user': 'pebbles', 'age': 1, 'active': false } * ] * * partition(users, ({ active }) => active) * // => objects for [['fred'], ['barney', 'pebbles']] */ //将一个集合的元素分成两组数组,然后返回这两组数组组成的数组。第一个数组是遍历后predicate返回true的所有元素,第二个数组是遍历后predicate返回false的所有元素 function partition(collection, predicate) { return reduce(collection, (result, value, key) => ( result[predicate(value) ? 0 : 1].push(value), result ), [[], []]) //调用reduce方法遍历,对每一个集合中的元素调用predicate,返回true的元素存入result[0],否则result[1] } export default partition
reduce
import arrayReduce from './.internal/arrayReduce.js' import baseEach from './.internal/baseEach.js' import baseReduce from './.internal/baseReduce.js' /** * Reduces `collection` to a value which is the accumulated result of running * each element in `collection` thru `iteratee`, where each successive * invocation is supplied the return value of the previous. If `accumulator` * is not given, the first element of `collection` is used as the initial * value. The iteratee is invoked with four arguments: * (accumulator, value, index|key, collection). * * Many lodash methods are guarded to work as iteratees for methods like * `reduce`, `reduceRight`, and `transform`. * * The guarded methods are: * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`, * and `sortBy` * * @since 0.1.0 * @category Collection * @param {Array|Object} collection The collection to iterate over. * @param {Function} iteratee The function invoked per iteration. * @param {*} [accumulator] The initial value. * @returns {*} Returns the accumulated value. * @see reduceRight, transform * @example * * reduce([1, 2], (sum, n) => sum + n, 0) * // => 3 * * reduce({ 'a': 1, 'b': 2, 'c': 1 }, (result, value, key) => { * (result[value] || (result[value] = [])).push(key) * return result * }, {}) * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed) */ //将每一个集合中的元素通过iteratee处理后的结果累加到一个值,每一次连续的调用的累加值都是上一次的返回值。如果初始累加值没有提供,就使用第一次循环的返回值 function reduce(collection, iteratee, accumulator) { const func = Array.isArray(collection) ? arrayReduce : baseReduce//判断collection参数是数组还是其他类型,如果是数组调用arrayReduce,否则baseReduce const initAccum = arguments.length < 3 return func(collection, iteratee, accumulator, initAccum, baseEach) } export default reduce

浙公网安备 33010602011771号