| 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 corresponding value of |
| * each key is the number of times the key was returned by `iteratee`. The |
| * iteratee is invoked with one argument: (value). |
| * |
| * @static |
| * @memberOf _ |
| * @since 0.5.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 |
| * |
| * _.countBy([6.1, 4.2, 6.3], Math.floor); |
| * // => { '4': 1, '6': 2 } |
| * |
| * // The `_.property` iteratee shorthand. |
| * _.countBy(['one', 'two', 'three'], 'length'); |
| * // => { '3': 2, '5': 1 } |
| */ |
| var countBy = createAggregator(function(result, value, key) { |
| if (hasOwnProperty.call(result, key)) { |
| ++result[key]; |
| } else { |
| baseAssignValue(result, key, 1); |
| } |
| }); |
| |
| module.exports = countBy; |