Urara-Blog/node_modules/.pnpm-store/v3/files/12/a68d1318886f8786565e44debcf9bf28c4ac4548030542f68f98c1183585090064f99fea9357242e8127ea093131662988ec99adcecc3d823a42a4d459ba9c
2022-08-14 01:14:53 +08:00

39 lines
1 KiB
Text

var apply = require('./_apply'),
arrayMap = require('./_arrayMap'),
unzip = require('./unzip');
/**
* This method is like `_.unzip` except that it accepts `iteratee` to specify
* how regrouped values should be combined. The iteratee is invoked with the
* elements of each group: (...group).
*
* @static
* @memberOf _
* @since 3.8.0
* @category Array
* @param {Array} array The array of grouped elements to process.
* @param {Function} [iteratee=_.identity] The function to combine
* regrouped values.
* @returns {Array} Returns the new array of regrouped elements.
* @example
*
* var zipped = _.zip([1, 2], [10, 20], [100, 200]);
* // => [[1, 10, 100], [2, 20, 200]]
*
* _.unzipWith(zipped, _.add);
* // => [3, 30, 300]
*/
function unzipWith(array, iteratee) {
if (!(array && array.length)) {
return [];
}
var result = unzip(array);
if (iteratee == null) {
return result;
}
return arrayMap(result, function(group) {
return apply(iteratee, undefined, group);
});
}
module.exports = unzipWith;