isError.js 959 B

123456789101112131415161718192021222324252627282930313233343536
  1. import baseGetTag from './_baseGetTag.js';
  2. import isObjectLike from './isObjectLike.js';
  3. import isPlainObject from './isPlainObject.js';
  4. /** `Object#toString` result references. */
  5. var domExcTag = '[object DOMException]',
  6. errorTag = '[object Error]';
  7. /**
  8. * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,
  9. * `SyntaxError`, `TypeError`, or `URIError` object.
  10. *
  11. * @static
  12. * @memberOf _
  13. * @since 3.0.0
  14. * @category Lang
  15. * @param {*} value The value to check.
  16. * @returns {boolean} Returns `true` if `value` is an error object, else `false`.
  17. * @example
  18. *
  19. * _.isError(new Error);
  20. * // => true
  21. *
  22. * _.isError(Error);
  23. * // => false
  24. */
  25. function isError(value) {
  26. if (!isObjectLike(value)) {
  27. return false;
  28. }
  29. var tag = baseGetTag(value);
  30. return tag == errorTag || tag == domExcTag ||
  31. (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));
  32. }
  33. export default isError;