Typa: Zero-dep JS type checker 🧐
The easy-peasy zero-dependency JavaScript type checker that asks, "What typa input is that?" Minified packaged version is 2 entire KB.
Notice: Breaking changes in v0.3.0. New bundler, plus nll
is now nil
and noru
is now nullish
.
Install
yarn add typa || npm install typa
Run tests
yarn test
Basic Usage
import is from 'typa' || const is = require('typa')
const hello = 'Hello!'
const goodbye = ['Goodbye!', 'Adios!', 'Au revoir!']
if (is.str(hello)) console.log(hello)
if (is.str(goodbye)) console.log(hello)
API
Typa Method
Ternary operator that checks if the supplied value matches the specified type, then returns the first callback function or value if true or the second callback function or value if false.
.typa($type, $value, $fn1, $fn2)
const isStr = () => console.log('I am a string')
const aintStr = () => console.log('I am not a string')
is.typa('str', 'Am I a string?', isStr, aintStr)
is.typa('str', ['Am', 'I', 'a', 'string', '?'], isStr, aintStr)
What Method
Returns a string or an array of strings matching the type of the supplied value.
.what($value)
is.what('This is a string')
is.what(['This', 'is', 'an', 'array'])
Individual Type Methods
.arr($value) — Array
const isArray = is.arr(['text', 12])
.bad($value) — Null, undefined, empty, or an error
let isBad = is.bad(null)
isBad = is.bad(undefined)
isBad = is.bad({})
isBad = is.bad(new Error('This is an error'))
.bool($value) — Boolean
let isBool = is.bool(true)
isBool = is.bool(false)
.date($value) — Date
const isDate = is.date(new Date())
.empty($value) — Empty string, array, or object
let isEmpty = is.empty('')
isEmpty = is.empty([])
isEmpty = is.empty({})
.err($value) — Error
const isErr = is.err(new Error('This is an error.'))
.fn($value) — Function
const isFn = is.fn(() => {
console.log('Hi!')
})
.int($value) — Integer
const isInt = is.int(12)
.json($value, $type ['str'|'obj']) — JSON string (default) or object
let isJson = is.json('{"key": "value"}')
isJson = is.json({ key: 'value' }, 'obj')
.nil($value) — Null
const isNil = is.nil(null)
.nullish($value) — Null or Undefined
let isNullish = is.nullish(null)
isNullish = is.nullish(undefined)
.num($value) — Number
const isNum = is.num(28.2)
.obj($value) — Object
const isObj = is.obj({ key: 'value' })
.prom($value) — Promise
const myPromise = new Promise((resolve, reject) => {
try {
console.log('I make a promise to you')
resolve()
} catch (err) {
reject(err)
}
})
const isProm = is.prom(myPromise)
.regex($value) — Regular Expression
const isRegex = is.regex(new Regex(/\W/))
.str($value) — String
const isStr = is.str('text')
.sym($value) — Symbol
const isSym = is.sym(Symbol(42))
.undef($value) — Undefined
const isUndef = is.undef(undefined)
Author
👤 Daniel Sieradski hello@self.agency
Acknowledgements
Most of the checks comprising this library were pilfered from this blog post by Webbjocke.
Contributing
Contributions, issues and feature requests are welcome!
Feel free to check issues page.
Show your support
Give a ⭐️ if this project helped you!