| var baseGetTag = require('./_baseGetTag'), |
| isObjectLike = require('./isObjectLike'); |
| |
| /** `Object#toString` result references. */ |
| var numberTag = '[object Number]'; |
| |
| /** |
| * Checks if `value` is classified as a `Number` primitive or object. |
| * |
| * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are |
| * classified as numbers, use the `_.isFinite` method. |
| * |
| * @static |
| * @memberOf _ |
| * @since 0.1.0 |
| * @category Lang |
| * @param {*} value The value to check. |
| * @returns {boolean} Returns `true` if `value` is a number, else `false`. |
| * @example |
| * |
| * _.isNumber(3); |
| * // => true |
| * |
| * _.isNumber(Number.MIN_VALUE); |
| * // => true |
| * |
| * _.isNumber(Infinity); |
| * // => true |
| * |
| * _.isNumber('3'); |
| * // => false |
| */ |
| function isNumber(value) { |
| return typeof value == 'number' || |
| (isObjectLike(value) && baseGetTag(value) == numberTag); |
| } |
| |
| module.exports = isNumber; |