Type Utilities
A tiny tree shakable utility library for runtime type checking.
The entire package weighs in at 657 bytes
.
See live demo.
Why this package?
This package exposes re-usable runtime type checking functions. This is useful for shrinking bundle sizes.
How to install
Install @analytics/types-utils
from npm.
npm install @analytics/types-utils
API
Below is the api for @analytics/types-utils
.
isBrowser
Check if currently in browser context
import { isBrowser } from '@analytics/types-utils'
if (isBrowser) {
console.log('do things in browser env')
}
isString
Check if value is string
import { isString } from '@analytics/types-utils'
const xyz = 'hi'
console.log(isString(xyz))
isNumber
Check if value is number
import { isNumber } from '@analytics/types-utils'
const xyz = 123
console.log(isNumber(xyz))
isBoolean
Check if value is boolean
import { isBoolean } from '@analytics/types-utils'
const myBool = true
console.log(isBoolean(myBool))
isArray
Check if value is array
import { isArray } from '@analytics/types-utils'
const myArr = ['x', 'y']
console.log(isArray(myArr))
isObject
Check if value is object
import { isObject } from '@analytics/types-utils'
const myObj = { cool: 'hello' }
console.log(isObject(myObj))
isUndefined
Check if value is undefined
import { isUndefined } from '@analytics/types-utils'
let myval
console.log(isUndefined(myval))
isRegex
Check if value is regular expression.
import { isRegex } from '@analytics/types-utils'
let myval = /pattern/gm
console.log(isRegex(myval))
isNoOp
Check if value is a noOp
function.
import { isNoOp } from '@analytics/types-utils'
function empty () { }
console.log(isNoOp(isNoOp))
isTruthy
Check if value is truthy.
import { isTruthy } from '@analytics/types-utils'
console.log(isTruthy(''))
console.log(isTruthy('false'))
console.log(isTruthy('FALSE'))
console.log(isTruthy(0))
console.log(isTruthy(null))
console.log(isTruthy(undefined))
console.log(isTruthy('true'))
console.log(isTruthy(1))
console.log(isTruthy({}))
console.log(isTruthy([]))
console.log(isTruthy(function() { }))
isElement
Check if value is a a DOM node.
import { isElement } from '@analytics/types-utils'
const formElement = document.querySelector('.my-form')
console.log(isElement(formElement))
isNodeList
Check if value is a list of DOM nodes.
import { isNodeList } from '@analytics/types-utils'
const buttons = document.querySelectorAll('button')
console.log(isNodeList(buttons))
isForm
Check if value is a noOp
function.
import { isForm } from '@analytics/types-utils'
const formElement = document.querySelector('.my-form')
console.log(isForm(formElement))