| 1234567891011121314151617181920212223242526272829303132333435363738394041 | 
							- var baseAssignValue = require('./_baseAssignValue'),
 
-     createAggregator = require('./_createAggregator');
 
- /** Used for built-in method references. */
 
- var objectProto = Object.prototype;
 
- /** Used to check objects for own properties. */
 
- var hasOwnProperty = objectProto.hasOwnProperty;
 
- /**
 
-  * Creates an object composed of keys generated from the results of running
 
-  * each element of `collection` thru `iteratee`. The order of grouped values
 
-  * is determined by the order they occur in `collection`. The corresponding
 
-  * value of each key is an array of elements responsible for generating the
 
-  * key. The iteratee is invoked with one argument: (value).
 
-  *
 
-  * @static
 
-  * @memberOf _
 
-  * @since 0.1.0
 
-  * @category Collection
 
-  * @param {Array|Object} collection The collection to iterate over.
 
-  * @param {Function} [iteratee=_.identity] The iteratee to transform keys.
 
-  * @returns {Object} Returns the composed aggregate object.
 
-  * @example
 
-  *
 
-  * _.groupBy([6.1, 4.2, 6.3], Math.floor);
 
-  * // => { '4': [4.2], '6': [6.1, 6.3] }
 
-  *
 
-  * // The `_.property` iteratee shorthand.
 
-  * _.groupBy(['one', 'two', 'three'], 'length');
 
-  * // => { '3': ['one', 'two'], '5': ['three'] }
 
-  */
 
- var groupBy = createAggregator(function(result, value, key) {
 
-   if (hasOwnProperty.call(result, key)) {
 
-     result[key].push(value);
 
-   } else {
 
-     baseAssignValue(result, key, [value]);
 
-   }
 
- });
 
- module.exports = groupBy;
 
 
  |