2016-01-28 01:16:24 -08:00
|
|
|
define(['./_baseFlatten'], function(baseFlatten) {
|
2015-01-08 00:37:01 -08:00
|
|
|
|
2016-02-15 20:20:54 -08:00
|
|
|
/** Used as references for various `Number` constants. */
|
|
|
|
|
var INFINITY = 1 / 0;
|
|
|
|
|
|
2015-01-08 00:37:01 -08:00
|
|
|
/**
|
2016-02-15 20:20:54 -08:00
|
|
|
* Recursively flattens `array`.
|
2015-01-08 00:37:01 -08:00
|
|
|
*
|
|
|
|
|
* @static
|
|
|
|
|
* @memberOf _
|
2016-03-26 00:00:01 -07:00
|
|
|
* @since 3.0.0
|
2015-01-08 00:37:01 -08:00
|
|
|
* @category Array
|
2016-02-15 20:20:54 -08:00
|
|
|
* @param {Array} array The array to flatten.
|
2015-01-08 00:37:01 -08:00
|
|
|
* @returns {Array} Returns the new flattened array.
|
|
|
|
|
* @example
|
|
|
|
|
*
|
2016-02-15 20:20:54 -08:00
|
|
|
* _.flattenDeep([1, [2, [3, [4]], 5]]);
|
|
|
|
|
* // => [1, 2, 3, 4, 5]
|
2015-01-08 00:37:01 -08:00
|
|
|
*/
|
|
|
|
|
function flattenDeep(array) {
|
2016-10-30 20:06:57 -07:00
|
|
|
var length = array == null ? 0 : array.length;
|
2016-02-15 20:20:54 -08:00
|
|
|
return length ? baseFlatten(array, INFINITY) : [];
|
2015-01-08 00:37:01 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return flattenDeep;
|
|
|
|
|
});
|