isBoolean.js 681 B

123456789101112131415161718192021222324252627282930
  1. var baseGetTag = require('./_baseGetTag'),
  2. isObjectLike = require('./isObjectLike');
  3. /** `Object#toString` result references. */
  4. var boolTag = '[object Boolean]';
  5. /**
  6. * Checks if `value` is classified as a boolean primitive or object.
  7. *
  8. * @static
  9. * @memberOf _
  10. * @since 0.1.0
  11. * @category Lang
  12. * @param {*} value The value to check.
  13. * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.
  14. * @example
  15. *
  16. * _.isBoolean(false);
  17. * // => true
  18. *
  19. * _.isBoolean(null);
  20. * // => false
  21. */
  22. function isBoolean(value) {
  23. return value === true || value === false ||
  24. (isObjectLike(value) && baseGetTag(value) == boolTag);
  25. }
  26. module.exports = isBoolean;