Learn about the available options, methods and use cases.
Usage
Following is the simple usage of this validator
import e from "validator";
await e.number(
{} // Optionally pass options
)
.validate(10) // returns 10
Options
Following are the available options for this validator
export interface INumberValidatorOptions extends TBaseValidatorOptions {
/** Pass custom messages for the errors */
messages?: Partial<
Record<
| "typeError"
| "smallerLength"
| "greaterLength"
| "smallerAmount"
| "greaterAmount"
| "notInt"
| "notFloat",
TErrorMessage
>
>;
/** Validate number is int */
isInt?: boolean;
/** Validate number is float */
isFloat?: boolean;
/** Validate number minimum length */
minLength?: number;
/** Validate number maximum length */
maxLength?: number;
/** Validate number minimum length */
minAmount?: number;
/** Validate number maximum length */
maxAmount?: number;
}
Methods
Following are the available methods on this validator
.length(options: { min?: number; max?: number } | number)
.amount(options: { min?: number; max?: number } | number)
.min(amount: number)
.max(amount: number)
.int()
.float()
Examples
Read the examples below to understand different use cases
Case 1 (Using validator options)
// Cast string to number
await e.number({ cast: true }).validate("1") // returns 1
// Alternatively you can do this (Using a utility validator)
await e.cast(e.number()).validate("1") // returns 1