# isNumber

Evaluates whether the given value is of type [Number](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number)

```javascript
import isNumber from 'deep-waters/isNumber';

isNumber(10); // → true

isNumber("10"); // → false
```

*isNumber*, like any other type validator, is mostly used in [composed](https://antonioru.gitbook.io/deep-waters/type-validators/broken-reference) validators:

```javascript
import isString from 'deep-waters/isString';
import matchesPattern from 'deep-waters/matchesPattern';

const isEmail = compose(
  isString,
  matchesPattern(/^\w+([.-]?\w+)*@\w+([.-]?\w+)*(\.\w{2,3})+$/),
);
```

{% hint style="success" %}
**isNumber** is built on top of [ofClass](https://antonioru.gitbook.io/deep-waters/validators/ofclass) validator and rely on `Object.prototype.toString` to check on the received value type in order to avoid [typeof weird behaviours ](https://stackoverflow.com/questions/18808226/why-is-typeof-null-object)and encouraging a **runtime strict type validation**.
{% endhint %}
