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; |