js-simple-validate
v1.0.41
Published
Simple javascript validate features
Downloads
64
Maintainers
Readme
js-simple-validate
The "js-simple-validate" package is a user-friendly and lightweight JavaScript library designed to simplify form validation on the client-side. With this package, developers can effortlessly validate form inputs to ensure data accuracy and enhance user experience.
Key features of "js-simple-validate" include:
- Seamless integration and minimal setup requirements for easy implementation.
- Support for validating various input types, including text, email, number, and password fields.
- Customizable error messages for informative feedback to users.
- Flexibility to perform both synchronous and asynchronous validation processes.
- Granular control over individual input validations or entire form validations.
Installation
npm install js-simple-validate
Menu
isAlphabet
isAscii
isFileName
isTextFile
isStrongPassword
isJsonObject
isPort
isFQDN
isURL
isGitURL
isEmail
isMailtoURI
isPostalCode
isMAC
isSemVer
isDataURI
isDate
isTime
isDecimal
isNumeric
isInt
isFullWidth
isHalfWidth
isSurrogatePair
isHash
isOctal
isHexadecimal
isHexColor
isHSL
isRgbColor
isLuhnNumber
isCreditCard
isJWT
isIP
isIPRange
isMagnetURI
isLatLong
isMobilePhone
isPassport
isMongoId
isMimeType
isUUID
isULID
isIMEI
isEAN
isCrockfordBase32
isBase32
isBase58
isBase64
isBitcoinAddress
isEthereumAddress
isNetworkError
API
isAlphabet(input)
Returns a Boolean indicating whether input
is alphabet characters or not.
import { isAlphabet } from "js-simple-validate";
console.log(isAlphabet("εηglish", "en-US")); // false
console.log(isAlphabet("English", "en-US")); // true
console.log(isAlphabet("русский", "ru-RU")); // true
console.log(isAlphabet("한국어", "ko-KR")); // true
isAscii(input)
Returns a Boolean indicating whether input
is ASCII characters or not.
import { isAscii } from "js-simple-validate";
console.log(isAscii("En99__--__?=([&!*])")); // true
console.log(isAscii("✂️ Copy and 📋 Paste Emoji 👍")); // false
console.log(isAscii("русский")); // false
console.log(isAscii("한국어")); // false
isFileName(input[, options])
Returns a Boolean indicating whether input
is valid file name or not.
options.requireExtension
: is aboolean
and defaults tofalse
. If set totrue
, file name must contain file extension. If set tofalse
, it will checkinput
as just file name.
import { isFileName } from "js-simple-validate";
console.log(isFileName("foo bar")); // true
console.log(isFileName("foo_bar")); // true
console.log(isFileName("foo/bar")); // false
console.log(isFileName("con")); // false, not allowed file name
console.log(isFileName("foobar", { requireExtension: true })); // false, missing extension
console.log(isFileName("foobar.spec.ts2", { requireExtension: true })); // false, extension contains number
isTextFile(input)
Returns a Boolean indicating whether input
is text file or not.
import { isTextFile } from "js-simple-validate";
console.log(isTextFile("foo bar.txt")); // true
console.log(isTextFile("foo_bar.spec.ts")); // true
console.log(isTextFile("foo_bar.exe")); // false
isStrongPassword(input, options)
Returns a Boolean indicating whether input
is strong password or not.
options.minLength
: is anumber
and required. Determine the minimum length of password.options.minLowercase
: is anumber
and default to0
. Determine the minimum lowercase characters of password.options.minUppercase
: is anumber
and default to0
. Determine the minimum uppercase characters of password.options.minNumbers
: is anumber
and default to0
. Determine the minimum number characters of password.options.minSymbols
: is anumber
and default to0
. Determine the minimum symbol characters of password.
import { isStrongPassword } from "js-simple-validate";
console.log(
isStrongPassword("Admin@123", {
minLength: 8,
minLowercase: 1,
minUppercase: 1,
minNumbers: 1,
minSymbols: 1,
})
); // true
console.log(isStrongPassword("abc123", { minLength: 8 })); // false
isJsonObject(input)
Returns a Boolean indicating whether input
is a valid JSON object or not.
import { isJsonObject } from "js-simple-validate";
console.log(isJsonObject("{"key":1}")); // true
console.log(isJsonObject("[{"x":1,"y":1}]")); // true
console.log(isJsonObject("[1,2,3]")); // false
isPort(input)
Returns a Boolean indicating whether input
is port number or not.
Port number must be between 0 and 65535
import { isPort } from "js-simple-validate";
console.log(isPort("80")); // true
console.log(isPort("3000")); // true
console.log(isPort("100000")); // false
console.log(isPort("0080")); // false
console.log(isPort("-3000")); // false
isFQDN(input[, options])
Returns a Boolean indicating whether input
is Fully qualified domain name (FQDN)
or not.
options.requireTopLevelDomain
: is aboolean
and defaults tofalse
. If set totrue
, it will requireTop level domain (TLD)
part at the end.options.allowUnderscores
: is aboolean
and defaults tofalse
. If set totrue
, the FQDN can contain underscore character.options.allowTrailingDot
: is aboolean
and defaults tofalse
. If set totrue
, the FQDN can have dot character at the end.options.allowWildcard
: is aboolean
and defaults tofalse
. If set totrue
, the FQDN can have wildcard character (*).options.allowNumericTLD
: is aboolean
and defaults tofalse
. If set totrue
, theTop level domain (TLD)
can contains digits.options.ignoreMaxLength
: is aboolean
and defaults tofalse
. If set totrue
, each part of FQDN can have characters length greater than 63.
import { isFQDN } from "js-simple-validate";
console.log(isFQDN("www.google.com")); // true
console.log(isFQDN("www.google_meet.com", { allowUnderscores: true })); // true
console.log(
isFQDN("www.google.com123", {
requireTopLevelDomain: true,
allowNumericTLD: true,
})
); // true
console.log(isFQDN("*.netlify.app", { allowWildcard: true })); // true
console.log(isFQDN("www.g😃😃gle.com")); // false
isURL(input[, options])
Returns a Boolean indicating whether input
is URL or not.
options.requireProtocol
: is aboolean
and defaults tofalse
. If set totrue
, it will require protocol of URL.options.allowFragments
: is aboolean
and defaults tofalse
. If set totrue
, the URL can contain fragment.options.allowQueries
: is aboolean
and defaults tofalse
. If set totrue
, the URL can contain query components.options.allowRelativeProtocol
: is aboolean
and defaults tofalse
. If set totrue
, the URL can start with relative protocol.
import { isURL } from "js-simple-validate";
console.log(isURL("https://www.google.com:3000")); // true
console.log(isURL("http://[1080:0:0:0:8:800:200C:417A]:8000")); // true
console.log(isURL("https://username:[email protected]")); // true
console.log(isURL("//www.google.com", { allowRelativeProtocol: true })); // true
console.log(
isURL("https://www.google.com#basic", {
allowFragments: true,
})
); // true
console.log(
isURL("https://www.google.com?title=title", {
allowQueries: true,
})
); // true
console.log(isURL("www.google.com", { requireProtocol: true })); // false
isGitURL(input)
Returns a Boolean indicating whether input
is Git URL or not.
import { isGitURL } from "js-simple-validate";
console.log(isGitURL("git://github.com/repo/is-git-url.git")); // true
console.log(isGitURL("ssh://[email protected]:12345/repository.git")); // true
console.log(isGitURL("https://github.com/repo/my-app.git")); // true
console.log(isGitURL("github.com/repo/my-app.git")); // false
console.log(isGitURL("https://github.com/repo/my-app")); // false
isEmail(input)
Returns a Boolean indicating whether input
is email or not.
import { isEmail } from "js-simple-validate";
console.log(isEmail("[email protected]")); // true
console.log(isEmail("[email protected]")); // true
console.log(isEmail("[email protected]")); // false
console.log(isEmail("[email protected]")); // false
console.log(isEmail("あいうえお@example.com")); // false
isMailtoURI(input)
Returns a Boolean indicating whether input
is Mailto URI or not.
import { isMailtoURI } from "js-simple-validate";
console.log(
isMailtoURI(
"mailto:[email protected]?subject=my-subject&body=my-body&[email protected]"
)
); // true
console.log(
isMailtoURI(
"mailto:[email protected]?title=my-subject&body=my-body&[email protected]"
)
); // false
isPostalCode(input[, locale])
Returns a Boolean indicating whether input
is postal code or not.
locale
: is aLocale
of postal code. If not set, it will check all locales until match theinput
string.
import { isPostalCode } from "js-simple-validate";
console.log(isPostalCode("94812-4444", "US")); // true
console.log(isPostalCode("94812-444", "US")); // false
isMAC(input[, options])
Returns a Boolean indicating whether input
is MAC address or not.
options.noSeparators
: is aboolean
and defaults tofalse
. If set totrue
, it will allow MAC addresses without separators.
import { isMAC } from "js-simple-validate";
console.log(isMAC("00:1A:2B:3C:4D:5E")); // true
console.log(isMAC("A1-B2-C3-D4-E5-F6")); // true
console.log(isMAC("001A.2B3C.4D5E")); // true
console.log(isMAC("001A2B3C4D5E", { noSeparators: true })); // true
console.log(isMAC("001A2B3C4D5E")); // false
console.log(isMAC("A1:B2C3.D4-E5F6")); // false
console.log(isMAC("GG:XX:YY:ZZ:4D:5E")); // false
isSemVer(input)
Returns a Boolean indicating whether input
is Semantic Version or not.
import { isSemVer } from "js-simple-validate";
console.log(isSemVer("1.0.0")); // true
console.log(isSemVer("1.2.3-alpha")); // true
console.log(isSemVer("2.0.0-beta.1")); // true
console.log(isSemVer("2.1.0+build.123")); // true
console.log(isSemVer("1")); // false
console.log(isSemVer("1.01.1")); // false
console.log(isSemVer("alpha+beta")); // false
isDataURI(input)
Returns a Boolean indicating whether input
is Data URI format or not.
import { isDataURI } from "js-simple-validate";
console.log(isDataURI("data:text/plain;base64,SGVsbG8sIFdvcmxkIQ==")); // true
console.log(isDataURI("data:text/plain,SGVsbG8sIFdvcmxkIQ==")); // true
console.log(isDataURI(",AACkQBADs")); // true
console.log(isDataURI("data::text/plain,SGVsbG8sIFdvcmxkIQ==")); // false
console.log(isDataURI("text/plain,SGVsbG8sIFdvcmxkIQ==")); // false
console.log(isDataURI("data:text/plain;base64")); // false
isDate(input[, options])
Returns a Boolean indicating whether input
is Date string or not.
options.format
: is astring
and defaults toYYYY/MM/DD
.options.strictMode
: is aboolean
and defaults tofalse
. If set totrue
, it will check exactly specific format.
import { isDate } from "js-simple-validate";
console.log(isDate("2024-12-25")); // true
console.log(isDate("2024/12/25")); // true
console.log(isDate("25.12.2024", { format: "DD.MM.YYYY", strictMode: true })); // true
console.log(isDate("25.12.2024", { format: "DD-MM-YYYY", strictMode: true })); // false
isTime(input[, options])
Returns a Boolean indicating whether input
is Time string or not.
options.hourFormat
: is the format of hour, one of['12', '24']
. If not set, it will check both hour12
and24
formats.options.withSeconds
: is aboolean
and defaults tofalse
. If set totrue
, it will check exactly time contains seconds.
import { isTime } from "js-simple-validate";
console.log(isTime("23:12:30")); // true
console.log(isTime("00:12", { hourFormat: "12" })); // true
console.log(isTime("23:12", { hourFormat: "12" })); // false
console.log(isTime("23:12:30", { withSeconds: true })); // true
console.log(isTime("23:12", { withSeconds: true })); // false
isDecimal(input[, options])
Returns a Boolean indicating whether input
is decimal number or not.
options.digits
: is anumber
and defaults to1
. Is the minimum digits of decimal.options.force
: is aboolean
and defaults tofalse
. If set totrue
, it will check exactly a decimal that has dot symbol and digits.
import { isDecimal } from "js-simple-validate";
console.log(isDecimal("123")); // true
console.log(isDecimal("-123.5")); // true
console.log(isDecimal("+123.5000")); // true
console.log(isDecimal("--123.4")); // false
console.log(isDecimal("123..4")); // false
console.log(isDecimal("123", { force: true })); // false
console.log(isDecimal("123.4", { digits: 3 })); // false
isNumeric(input[, options])
Returns a Boolean indicating whether input
is numeric number or not.
options.noSymbols
: is aboolean
and defaults tofalse
. If set totrue
, it will not allow any symbols except digits.
import { isNumeric } from "js-simple-validate";
console.log(isNumeric("123")); // true
console.log(isNumeric("-123.5")); // true
console.log(isNumeric("+123.5000")); // true
console.log(isNumeric("--123.4")); // false
console.log(isNumeric("123.4", { noSymbols: true })); // false
console.log(isNumeric("-123", { noSymbols: true })); // false
isInt(input[, options])
Returns a Boolean indicating whether input
is integer number or not.
options.leadingZeros
: is aboolean
and defaults tofalse
. If set totrue
, it will allow leading zeros in integer.options.min
: is anumber
. Is the minimum value of integer.options.max
: is anumber
. Is the maximum value of integer.options.gt
: is anumber
. The integer must be greater than this value.options.lt
: is anumber
. The integer must be less than this value.
import { isInt } from "js-simple-validate";
console.log(isInt("123")); // true
console.log(isInt("123.5")); // false
console.log(isInt("0012")); // false
console.log(isInt("0012", { leadingZeros: true })); // true
console.log(isInt("3", { min: 1, max: 3 })); // true
console.log(isInt("5", { min: 1, max: 3 })); // false
console.log(isInt("2", { gt: 1, lt: 3 })); // true
console.log(isInt("3", { gt: 1, lt: 3 })); // false
isFullWidth(input)
Returns a Boolean indicating whether input
only has full-width characters or not.
import { isFullWidth } from "js-simple-validate";
console.log(isFullWidth("Alice was beginning")); // true
console.log(isFullWidth("Alice was beginning")); // false
console.log(isFullWidth("日本語組版処理の要件")); // true
isHalfWidth(input)
Returns a Boolean indicating whether input
only has half-width characters or not.
import { isHalfWidth } from "js-simple-validate";
console.log(isHalfWidth("Alice was beginning")); // true
console.log(isHalfWidth("Alice was beginning")); // false
console.log(isHalfWidth("サンプル")); // true
console.log(isHalfWidth("日本語組版処理の要件")); // false
isSurrogatePair(input)
Returns a Boolean indicating whether input
only has surrogate pair characters or not.
Surrogate pair is represented by 2 characters of UTF-16
import { isSurrogatePair } from "js-simple-validate";
console.log(isSurrogatePair("😁🍕")); // true
console.log(isSurrogatePair("123")); // false
isHash(input, algorithm)
Returns a Boolean indicating whether input
is valid hash string based on hash algorithm or not.
algorithm
: is a hash algorithm. Is one of['crc32', 'crc32b', 'md4', 'md5', 'ripemd128', 'ripemd160', 'sha1', 'sha256', 'sha384', 'sha512', 'tiger128', 'tiger160', 'tiger192'
.
import { isHash } from "js-simple-validate";
console.log(isHash("6aaeb5af1a33e5c77e546224eb33de9", "md5")); // true
console.log(isHash("6aaeb5af", "crc32")); // true
console.log(isHash("サンプル", "crc32")); // false
console.log(isHash("6aaeb5af1a33e5c7", "sha256")); // false
isOctal(input, algorithm)
Returns a Boolean indicating whether input
is octal number or not.
import { isOctal } from "js-simple-validate";
console.log(isOctal("01234567")); // true
console.log(isOctal("0o1234567")); // true
console.log(isOctal("AB1010")); // false
console.log(isOctal("0x01234567")); // false
<a id="is-hexadecimal" href="#is-hexadecimal"">isHexadecimal(input, algorithm)
Returns a Boolean indicating whether input
is hexadecimal or not.
import { isHexadecimal } from "js-simple-validate";
console.log(isHexadecimal("AB0C5342F")); // true
console.log(isHexadecimal("0xAB0C5342F")); // true
console.log(isHexadecimal("0hAB0C5342F")); // true
console.log(isHexadecimal("XYZ")); // false
console.log(isHexadecimal("0bABC123")); // false
isHexColor(input)
Returns a Boolean indicating whether input
is HEX color or not.
import { isHexColor } from "js-simple-validate";
console.log(isHexColor("FFAABB00")); // true
console.log(isHexColor("FFAA00")); // true
console.log(isHexColor("#FFF")); // true
console.log(isHexColor("#VCLVCL")); // false
isHSL(input)
Returns a Boolean indicating whether input
is HSL color or not.
import { isHSL } from "js-simple-validate";
console.log(isHSL("hsl(120,100%,50%)")); // true
console.log(isHSL("hsl(120deg 100% 50%)")); // true
console.log(isHSL("hsla(-0.5e2rad -100% -2.5%)")); // true
console.log(isHSL("hsl(120,100,50)")); // false
console.log(isHSL("hsl(120% 100% 50%)")); // false
isRgbColor(input)
Returns a Boolean indicating whether input
is RGB (or RGBA) color or not.
import { isRgbColor } from "js-simple-validate";
console.log(isRgbColor("rgb(255,255,255)")); // true
console.log(isRgbColor("rgba(255,255,255,0.5)")); // true
console.log(isRgbColor("rgb(50%,50%,50%)")); // true
console.log(isRgbColor("rgb(300,300,300)")); // false
console.log(isRgbColor("rgb(200%,200%,200%)")); // false
console.log(isRgbColor("rgba(255,255,255,1.5)")); // false
isLuhnNumber(input)
Returns a Boolean indicating whether input
is passing Luhn algorithm check or not.
Luhn algorithm is being used for checking the accuracy of MasterCard, American Express (AMEX), Visa number.
import { isLuhnNumber } from "js-simple-validate";
console.log(isLuhnNumber("555555-555555-4444")); // true
console.log(isLuhnNumber("4111111111111111")); // true
console.log(isLuhnNumber("12345678")); // false
console.log(isLuhnNumber("dummy-text")); // false
isCreditCard(input[, provider])
Returns a Boolean indicating whether input
is valid Credit card number or not.
provider
: isprovider
name of credit card. Is one of['amex' | 'dinersclub' | 'discover' | 'jcb' | 'mastercard' | 'unionpay' | 'visa']
. All supported providers are extracted atCreditCardType
type.
import { isCreditCard } from "js-simple-validate";
console.log(isCreditCard("6212345678900000003")); // true
console.log(isCreditCard("378282246310005", "amex")); // true
console.log(isCreditCard(isCreditCard("2222420000001113", "mastercard"))); // true
console.log(isCreditCard("12345678")); // false
console.log(isCreditCard("dummy-text")); // false
isJWT(input)
Returns a Boolean indicating whether input
is JWT token or not.
import { isJWT } from "js-simple-validate";
console.log(isJWT("5eyJhbGciOi9.eyJzdWIiOiWF0TE2MjM5MDIyfQ.wpMeJf36POk6yJ5c")); // true
console.log(isJWT("anh.yêu.em")); // false
console.log(isJWT("abc.def.ghy.jwt")); // false
isIP(input[, version])
Returns a Boolean indicating whether input
is IP address or not.
version
: specify IP version. Is one of['IPv4', 'IPv6']
. If not set, it will check both v4 and v6 format.
import { isIP } from "js-simple-validate";
console.log(isIP("192.168.1.12")); // true
console.log(isIP("192.168.1.12", "IPv6")); // false
console.log(isIP("111:222:333:444:555:666:777:888")); // true
console.log(isIP("12:23::", "IPv6")); // true
console.log(isIP("1:2:3:4:5:6:192.168.1.12")); // true
isIPRange(input[, version])
Returns a Boolean indicating whether input
is IP range or not.
IP address range has an IP address and subnet mask separated by /
.
version
: specify IP version. Is one of['IPv4', 'IPv6']
. If not set, it will check both v4 and v6 format.
import { isIPRange } from "js-simple-validate";
console.log(isIPRange("192.168.1.12/20")); // true
console.log(isIPRange("192:168::/128", "IPv6")); // true
console.log(isIPRange("192.168.1.12/-20")); // false
console.log(isIPRange("12:23::/200", "IPv6")); // false
isMagnetURI(input)
Returns a Boolean indicating whether input
is Magnet URI or not.
import { isMagnetURI } from "js-simple-validate";
console.log(
isMagnetURI(
"magnet:?xt=urn:btih:5dee65101db281ac9c46344cd6b175cdcad53426&dn=download"
)
); // true
console.log(isMagnetURI("magnet:?xt=urn:fake:5deecd6&dn=download")); // false
isLatLong(input[, options])
Returns a Boolean indicating whether input
is LatLong value or not.
LatLong contains latitude and longitude separated by comma.
There are 2 formats: 12.123456,175.234125
and 12° 50' 57.4548'' N,24° 26' 0.9384'' E
options.checkDMS
: isboolean
, defaults tofalse
. If set totrue
, it will check by DMS format. If not set, it will check for both formats.options.dmsUnits
: isobject
, defaults to{ degree: "°", minute: "'", second: "''" }
. Is the unit of DMS.
import { isLatLong } from "js-simple-validate";
console.log(isLatLong("12.849293,24.433594")); // true
console.log(isLatLong("12.849293,24.433594", { checkDMS: true })); // false
console.log(isLatLong("12° 50' 57.4548'' N,24° 26' 0.9384'' E")); // true
console.log(
isLatLong("12deg 50min 57.4548sec N, 24deg 26min 0.9384sec E", {
dmsUnits: { degree: "deg", minute: "min", second: "sec" },
})
); // true
isMobilePhone(input, locale)
Returns a Boolean indicating whether input
is mobile phone number or not.
locale
: isLocale
or array ofLocale
. Is one of['en-US', 'vi-VN', ...]
. All supported locales are extracted atMobilePhoneLocale
type.
import { isMobilePhone } from "js-simple-validate";
console.log(isMobilePhone("0789550792", "vi-VN")); // true
console.log(isMobilePhone("+84789550792", "vi-VN")); // true
console.log(isMobilePhone("(555) 555-1234", "en-US")); // true
console.log(isMobilePhone("1234-555-1234", ["vi-VN", "en-US"])); // false
isPassport(input, locale)
Returns a Boolean indicating whether input
is valid passport number or not.
locale
: is the country code of passport. Is one of['JP', 'KR', 'US', ...]
. All supported locales are extracting atPassportLocale
type.
import { isPassport } from "js-simple-validate";
console.log(isPassport("123456789", "US")); // true
console.log(isPassport("AB1234567", "JP")); // true
isMongoId(input, locale)
Returns a Boolean indicating whether input
is mongo id or not.
import { isMongoId } from "js-simple-validate";
console.log(isMongoId("6592008029c8c3e4dc76256c")); // true
console.log(isMongoId("0x6592008029c8c3e4dc76256c")); // false
console.log(isMongoId("65920")); // false
isMimeType(input)
Returns a Boolean indicating whether input
is mime type or not.
import { isMimeType } from "js-simple-validate";
console.log(isMimeType("image/jpeg")); // true
console.log(isMimeType("text/plain; charset=UTF-8")); // true
console.log(isMimeType("multipart/form-data; boundary=aBoundaryString")); // true
isUUID(input)
Returns a Boolean indicating whether input
is UUID or not.
import { isUUID } from "js-simple-validate";
console.log(isUUID("3522ac6c-aadd-4165-8e10-d384faa5e076")); // true
console.log(isUUID("3522ac6c:aadd:4165:8e10:d384faa5e076")); // false
console.log(isUUID("0929:f3ea:4df4:86b0:dedf")); // false
isULID(input)
Returns a Boolean indicating whether input
is ULID string or not.
ULID (Universally Unique Lexicographically Sortable Identifier) is the alternative of UUID. It can be sorted and cannot be duplicated.
import { isULID } from "js-simple-validate";
console.log(isULID("01AN4Z07BY79KA1307SR9X4MV3")); // true
console.log(isULID("3522ac6c-aadd-4165-8e10-d384faa5e076")); // false
isIMEI(input[, options])
Returns a Boolean indicating whether input
is IMEI
number or not.
The IMEI (International Mobile Equipment Identity) number is a unique 15-digit serial number for identifying a device.
options.allowHyphens
: isboolean
, defaults tofalse
. If set totrue
, it will check IMEI number that contains hyphens.
import { isIMEI } from "js-simple-validate";
console.log(isIMEI("333909858444672")); // true
console.log(isIMEI("45-961095-155032-8", { allowHyphens: true })); // true
console.log(isIMEI("012345678912345")); // false
isEAN(input)
Returns a Boolean indicating whether input
is valid EAN
number or not.
The International Article Number (also known as European Article Number or EAN) is a standard describing a barcode symbology and numbering system used in global trade to identify a specific retail product type, in a specific packaging configuration, from a specific manufacturer.
There are most common EAN standard: EAN-8, EAN-13 and EAN/UCC-14.
import { isEAN } from "js-simple-validate";
console.log(isEAN("50123452")); // true
console.log(isEAN("5012345678900")); // true
console.log(isEAN("0123456789")); // false
isCrockfordBase32(input)
Returns a Boolean indicating whether input
is Base32 string as Crockford algorithm or not.
import { isCrockfordBase32 } from "js-simple-validate";
console.log(
isCrockfordBase32(
"AHM6A83HENMP6TS0C9S6YXVE41K6YY10D9TPTW3K41QQCSBJ41T6GS90DHGQMY90CHQPEBG"
)
); // true
console.log(isCrockfordBase32("invalidbase32")); // false
isBase32(input)
Returns a Boolean indicating whether input
is Base32 string or not.
import { isBase32 } from "js-simple-validate";
console.log(isBase32("JBSWY3DPEBLW64TMMQQQ====")); // true
console.log(isBase32("invalid base32")); // false
isBase58(input)
Returns a Boolean indicating whether input
is Base58 string or not.
import { isBase58 } from "js-simple-validate";
console.log(isBase58("L4baC6eDpmHZ5cmx2BMHZQPvwnokx9yPhE6jFGJBNHz4SU4ez9qH")); // true
console.log(isBase58("invalidbase58")); // false
isBase64(input[, options])
Returns a Boolean indicating whether input
is Base64 string or not.
options.isUrlSafe
: check with Url Safe Base64 format
import { isBase64 } from "js-simple-validate";
console.log(isBase64("SGVsbG8sIFdvcmxkIQ==")); // true
console.log(isBase64("SGVsbG8sIFdvcmxkIQ", { isUrlSafe: true })); // true
console.log(isBase64("invalid base64")); // false
console.log(isBase64("SGVsbG8sIFdvcmxkIQ==", { isUrlSafe: true })); // false
isBitcoinAddress(input)
Returns a Boolean indicating whether input
is Bitcoin address or not.
import { isBitcoinAddress } from "js-simple-validate";
console.log(isBitcoinAddress("1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa")); // true
console.log(isBitcoinAddress("invalid BTC")); // false
isEthereumAddress(input)
Returns a Boolean indicating whether input
is Ethereum address or not.
import { isEthereumAddress } from "js-simple-validate";
console.log(isEthereumAddress("0x71C7656EC7ab88b098defB751B7401B5f6d8976F")); // true
console.log(isEthereumAddress("71C7656EC7ab88b098defB751B7401B5f6d8976F")); // false
console.log(isEthereumAddress("0x12345")); // false
isNetworkError(input)
Returns a Boolean indicating whether input
is Network Error or not.
import { isNetworkError } from "js-simple-validate";
try {
await fetch("https://oyzaiz.abc/fake");
} catch (err) {
console.log(isNetworkError(err)); // true
}
try {
JSON.parse("invalid");
} catch (err) {
console.log(isNetworkError(err)); // false
}
License
MIT