root / HServer / 00.Server / 00.Program / node_modules / lodash / unzipWith.js
이력 | 보기 | 이력해설 | 다운로드 (1.02 KB)
| 1 |
var apply = require('./_apply'), |
|---|---|
| 2 |
arrayMap = require('./_arrayMap'),
|
| 3 |
unzip = require('./unzip');
|
| 4 |
|
| 5 |
/**
|
| 6 |
* This method is like `_.unzip` except that it accepts `iteratee` to specify
|
| 7 |
* how regrouped values should be combined. The iteratee is invoked with the
|
| 8 |
* elements of each group: (...group).
|
| 9 |
*
|
| 10 |
* @static
|
| 11 |
* @memberOf _
|
| 12 |
* @since 3.8.0
|
| 13 |
* @category Array
|
| 14 |
* @param {Array} array The array of grouped elements to process.
|
| 15 |
* @param {Function} [iteratee=_.identity] The function to combine
|
| 16 |
* regrouped values.
|
| 17 |
* @returns {Array} Returns the new array of regrouped elements.
|
| 18 |
* @example
|
| 19 |
*
|
| 20 |
* var zipped = _.zip([1, 2], [10, 20], [100, 200]);
|
| 21 |
* // => [[1, 10, 100], [2, 20, 200]]
|
| 22 |
*
|
| 23 |
* _.unzipWith(zipped, _.add);
|
| 24 |
* // => [3, 30, 300]
|
| 25 |
*/
|
| 26 |
function unzipWith(array, iteratee) { |
| 27 |
if (!(array && array.length)) {
|
| 28 |
return [];
|
| 29 |
} |
| 30 |
var result = unzip(array);
|
| 31 |
if (iteratee == null) { |
| 32 |
return result;
|
| 33 |
} |
| 34 |
return arrayMap(result, function(group) { |
| 35 |
return apply(iteratee, undefined, group); |
| 36 |
}); |
| 37 |
} |
| 38 |
|
| 39 |
module.exports = unzipWith; |