forEach.js 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import arrayEach from './_arrayEach.js';
  2. import baseEach from './_baseEach.js';
  3. import castFunction from './_castFunction.js';
  4. import isArray from './isArray.js';
  5. /**
  6. * Iterates over elements of `collection` and invokes `iteratee` for each element.
  7. * The iteratee is invoked with three arguments: (value, index|key, collection).
  8. * Iteratee functions may exit iteration early by explicitly returning `false`.
  9. *
  10. * **Note:** As with other "Collections" methods, objects with a "length"
  11. * property are iterated like arrays. To avoid this behavior use `_.forIn`
  12. * or `_.forOwn` for object iteration.
  13. *
  14. * @static
  15. * @memberOf _
  16. * @since 0.1.0
  17. * @alias each
  18. * @category Collection
  19. * @param {Array|Object} collection The collection to iterate over.
  20. * @param {Function} [iteratee=_.identity] The function invoked per iteration.
  21. * @returns {Array|Object} Returns `collection`.
  22. * @see _.forEachRight
  23. * @example
  24. *
  25. * _.forEach([1, 2], function(value) {
  26. * console.log(value);
  27. * });
  28. * // => Logs `1` then `2`.
  29. *
  30. * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {
  31. * console.log(key);
  32. * });
  33. * // => Logs 'a' then 'b' (iteration order is not guaranteed).
  34. */
  35. function forEach(collection, iteratee) {
  36. var func = isArray(collection) ? arrayEach : baseEach;
  37. return func(collection, castFunction(iteratee));
  38. }
  39. export default forEach;