https://github.com/openinf/openinf-util-types
Fundamental JavaScript type-related utilities
https://github.com/openinf/openinf-util-types
commonjs commonjs-module commonjs-package functional helpers helpers-library javascript javascript-library library nodejs npm npm-package predicate typechecking types typescript typescript-library typescript-package utilities
Last synced: about 1 month ago
JSON representation
Fundamental JavaScript type-related utilities
- Host: GitHub
- URL: https://github.com/openinf/openinf-util-types
- Owner: OpenINF
- License: other
- Created: 2021-01-17T03:43:17.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2025-04-01T16:18:42.000Z (about 2 months ago)
- Last Synced: 2025-04-01T17:38:34.797Z (about 2 months ago)
- Topics: commonjs, commonjs-module, commonjs-package, functional, helpers, helpers-library, javascript, javascript-library, library, nodejs, npm, npm-package, predicate, typechecking, types, typescript, typescript-library, typescript-package, utilities
- Language: TypeScript
- Homepage: https://github.com/OpenINF/openinf-util-types#readme
- Size: 335 KB
- Stars: 3
- Watchers: 3
- Forks: 2
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
- Security: SECURITY.md
- Authors: AUTHORS
Awesome Lists containing this project
README
## `@openinf/util-types`
> Fundamental JavaScript type-related utilities
[!['View on npm'][npm-badge--shields]][npm-badge-url]
[!['License: MIT/Apache-2.0'][license-badge--shields]][license-badge-url]
The high-level goal of `@openinf/util-types` is to serve as a Node.js package
containing utilities for **fundamental JavaScript type-related operations**
primarily enabling users to perform native typechecking and simplify type
coercion. We are constantly working to improve this repository, so please feel
free to [contribute](#contributing) if you notice any omissions or errors.Thanks!
Supported Node.js Environments
- [ ] v4:Argon (Ar)
- [ ] v6:Boron (B)
- [ ] v8:Carbon (C)
- [ ] v10:Dubnium (Db)
- [ ] v12:Erbium (Er)
- [x] v14:Fermium (Fm)
- [x] v16:Gallium (Ga)
- [x] v18:Hydrogen (H)
[![Code Style: Prettier][prettier-badge]][prettier-url]
[![Commit Style: Conventional Commits][conventional-commits-badge]][conventional-commits-url]
[![Chat on Matrix][matrix-badge--shields]][matrix-url]
---
### Table of Contents
- [Installation](#installation)
- [Usage](#usage)
- [API](#api)
- [Contributing](#contributing)
- [License](#license)
---
Installation
![]()
`@openinf/util-types` runs on
[supported versions of Node.js](#platform--node-js-lts) and is available via
**`npm`**, **`pnpm`**, or **`yarn`**.**Using the npm CLI**
See the
[official documentation for this command](https://docs.npmjs.com/cli/commands/npm-install)
for more information.```shell
npm i @openinf/util-types
```**Using the pnpm CLI**
See the [official documentation for this command](https://pnpm.io/cli/add)
for more information.```shell
pnpm add @openinf/util-types
```**Using the Yarn 1 CLI (Classic)**
See the
[official documentation for this command](https://classic.yarnpkg.com/en/docs/cli/add)
for more information.```shell
yarn add @openinf/util-types
```
### Usage
Import the helper functions based on your platform.
```ts
import { isObject } from '@openinf/util-types';const maybeObject = null;
if (isObject(maybeObject)) {
console.log('The value of `maybeObject` is of type Object.');
} else {
console.log('The value of `maybeObject` is not of type Object.');
}
```
### API
-
toString(value) ⇒string
-
Returns the ECMAScript [[Class]] internal property of the passed value.
-
isUndefined(value) ⇒boolean
-
Determines whether the passed value is actually of type
undefined
. -
isObject(value) ⇒boolean
-
Determines whether the passed value is of type
Object
. -
isOrdinaryFunction(value) ⇒boolean
-
Determines whether the passed value is of type
Function
. -
isBooleanObject(value) ⇒boolean
-
Determines whether the passed value is actually a
Boolean
object. -
isSymbolObject(value) ⇒boolean
-
Determines whether the passed value is actually a
Symbol
object. -
isNativeError(value) ⇒boolean
-
Determines whether the passed value is one of the native error types:
-
isNumberObject(value) ⇒boolean
-
Determines whether the passed value is actually a
Number
object (boxed primitive). -
isBigIntObject(value) ⇒boolean
-
Determines whether the passed value is actually a
BigInt
object (boxed primitive). -
isFiniteNumber(value) ⇒boolean
-
Determines whether the passed value is of number type and finite.
NaN
andInfinity
are not considered a finite number. String numbers are not
considered numbers. -
isMath(value) ⇒boolean
-
Determines whether the passed value is actually the
Math
global object. -
isDate(value) ⇒boolean
-
Determines whether the passed value is of type
Date
. -
isStringObject(value) ⇒boolean
-
Determines whether the passed value is actually a
String
object. -
isRegExp(value) ⇒boolean
-
Determines whether the passed value is of type
RegExp
. -
isArray(value) ⇒boolean
-
Determines whether the passed value is of type
Array
. -
toArray(arrayLike) ⇒Array<T>
-
Converts an array-like object to an array.
-
isInt8Array(value) ⇒boolean
-
Determines whether the passed value is of type
Int8Array
. -
isUint8Array(value) ⇒boolean
-
Determines whether the passed value is of type
Uint8Array
. -
isUint8ClampedArray(value) ⇒boolean
-
Determines whether the passed value is of type
Uint8ClampedArray
. -
isInt16Array(value) ⇒boolean
-
Determines whether the passed value is of type
Int16Array
. -
isUint16Array(value) ⇒boolean
-
Determines whether the passed value is of type
Uint16Array
. -
isInt32Array(value) ⇒boolean
-
Determines whether the passed value is of type
Int32Array
. -
isUint32Array(value) ⇒boolean
-
Determines whether the passed value is of type
Uint32Array
. -
isFloat32Array(value) ⇒boolean
-
Determines whether the passed value is of type
Float32Array
. -
isFloat64Array(value) ⇒boolean
-
Determines whether the passed value is of type
Float64Array
. -
isBigInt64Array(value) ⇒boolean
-
Determines whether the passed value is of type
BigInt64Array
. -
isBigUint64Array(value) ⇒boolean
-
Determines whether the passed value is of type
BigUint64Array
. -
isArrayBufferView(value) ⇒boolean
-
Determines whether the passed value is an
ArrayBufferView
,
which is a helper type representing any of the following JavaScript TypedArray
types:Int8Array
Uint8Array
Uint8ClampedArray
Int16Array
Uint16Array
Int32Array
Uint32Array
Float32Array
Float64Array
DataView
-
isTypedArray(value) ⇒boolean
-
Determines if value is one of the TypedArray element types:
Int8Array
Uint8Array
Uint8ClampedArray
Int16Array
Uint16Array
Int32Array
Uint32Array
Float32Array
Float64Array
BigInt64Array
BigUint64Array
-
isMap(value) ⇒boolean
-
Determines whether the passed value is of type
Map
. -
isMapIterator(value) ⇒boolean
-
Determines whether the passed value is of type
Map Iterator
. -
isSet(value) ⇒boolean
-
Determines whether the passed value is of type
Set
. -
isSetIterator(value) ⇒boolean
-
Determines whether the passed value is of type
Set Iterator
. -
isWeakMap(value) ⇒boolean
-
Determines whether the passed value is of type
WeakMap
. -
isWeakSet(value) ⇒boolean
-
Determines whether the passed value is of type
WeakSet
. -
isArrayBuffer(value) ⇒boolean
-
Determines whether the passed value is of type
ArrayBuffer
. -
isSharedArrayBuffer(value) ⇒boolean
-
Determines whether the passed value is of type
SharedArrayBuffer
. -
isAnyArrayBuffer(value) ⇒boolean
-
Determines whether the passed value is one of either
ArrayBuffer
orSharedArrayBuffer
. -
isDataView(value) ⇒boolean
-
Determines whether the passed value is of type
DataView
. -
isPromise(value) ⇒boolean
-
Determines whether the passed value is of type
Promise
. -
isGeneratorObject(value) ⇒boolean
-
Determines whether the passed value is actually a
Generator
object. -
isGeneratorFunction(value) ⇒boolean
-
Determines whether the passed value is of type
GeneratorFunction
. -
isAsyncFunction(value) ⇒boolean
-
Determines whether the passed value is of type
AsyncFunction
. -
isArgumentsObject(value) ⇒boolean
-
Determines whether the passed value is actually an
arguments
object. -
isBoxedPrimitive(value) ⇒boolean
-
Determines whether the passed value is a primitive wrapped by its object
equivalent (a.k.a. "boxed"). Except fornull
andundefined
, all primitive
values have object equivalents that wrap around the primitive values:
-
isModuleNamespaceObject(value) ⇒boolean
-
Determines whether the passed value is a
Module
namespace object. -
isPrimitive(value) ⇒boolean
-
Determines whether the passed value is of a primitive
data type.
#### toString(value) ⇒ string
Returns the ECMAScript [[Class]] internal property of the passed value.
**Kind**: global function
**Returns**: string
- A specification-defined classification of objects.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isUndefined(value) ⇒ boolean
Determines whether the passed value is actually of type [`undefined`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/undefined).
**Kind**: global function
**Returns**: boolean
- `true` if the value is `undefined`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isObject(value) ⇒ boolean
Determines whether the passed value is of type `Object`.
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `Object`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isOrdinaryFunction(value) ⇒ boolean
Determines whether the passed value is of type `Function`.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Function`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isBooleanObject(value) ⇒ boolean
Determines whether the passed value is actually a [`Boolean`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Boolean)
object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Boolean` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isSymbolObject(value) ⇒ boolean
Determines whether the passed value is actually a [`Symbol`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol)
object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Symbol` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isNativeError(value) ⇒ boolean
Determines whether the passed value is one of the native error types:
- [`EvalError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/EvalError)
- [`RangeError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RangeError)
- [`ReferenceError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/ReferenceError)
- [`SyntaxError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SyntaxError)
- [`TypeError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypeError)
- [`URIError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/URIError)
- [`AggregateError `](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError)
- [`InternalError`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/InternalError)
**Kind**: global function
**Returns**: boolean
- `true` if the value is a native error; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isNumberObject(value) ⇒ boolean
Determines whether the passed value is actually a [`Number`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number)
object (boxed primitive).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Number` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isBigIntObject(value) ⇒ boolean
Determines whether the passed value is actually a [`BigInt`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt)
object (boxed primitive).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `BigInt` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isFiniteNumber(value) ⇒ boolean
Determines whether the passed value is of number type and finite. `NaN` and
`Infinity` are not considered a finite number. String numbers are not
considered numbers.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a finite number; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isMath(value) ⇒ boolean
Determines whether the passed value is actually the [`Math`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math)
global object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is the `Math` object; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isDate(value) ⇒ boolean
Determines whether the passed value is of type [`Date`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Date`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isStringObject(value) ⇒ boolean
Determines whether the passed value is actually a [`String`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)
object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `String` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isRegExp(value) ⇒ boolean
Determines whether the passed value is of type [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `RegExp`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isArray(value) ⇒ boolean
Determines whether the passed value is of type [`Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `Array`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### toArray(arrayLike) ⇒ Array<T>
Converts an array-like object to an array.
**Kind**: global function
| Param | Type |
| --------- | ------------------------------------------------------- |
| arrayLike | ArrayLike<T>
\| string
|
#### isInt8Array(value) ⇒ boolean
Determines whether the passed value is of type [`Int8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int8Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `Int8Array`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isUint8Array(value) ⇒ boolean
Determines whether the passed value is of type [`Uint8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Uint8Array`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isUint8ClampedArray(value) ⇒ boolean
Determines whether the passed value is of type [`Uint8ClampedArray`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8ClampedArray).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Uint8ClampedArray`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isInt16Array(value) ⇒ boolean
Determines whether the passed value is of type [`Int16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int16Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `Int16Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isUint16Array(value) ⇒ boolean
Determines whether the passed value is of type [`Uint16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint16Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Uint16Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isInt32Array(value) ⇒ boolean
Determines whether the passed value is of type [`Int32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int32Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `Int32Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isUint32Array(value) ⇒ boolean
Determines whether the passed value is of type [`Uint32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint32Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Uint32Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isFloat32Array(value) ⇒ boolean
Determines whether the passed value is of type [`Float32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float32Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Float32Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isFloat64Array(value) ⇒ boolean
Determines whether the passed value is of type [`Float64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float64Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Float64Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isBigInt64Array(value) ⇒ boolean
Determines whether the passed value is of type [`BigInt64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt64Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `BigInt64Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isBigUint64Array(value) ⇒ boolean
Determines whether the passed value is of type [`BigUint64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigUInt64Array).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `BigUint64Array`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isArrayBufferView(value) ⇒ boolean
Determines whether the passed value is an [`ArrayBufferView`](https://developer.mozilla.org/en-US/docs/Web/API/ArrayBufferView),
which is a helper type representing any of the following JavaScript [**TypedArray**](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray)
types:
- [`Int8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int8Array)
- [`Uint8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)
- [`Uint8ClampedArray`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8ClampedArray)
- [`Int16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int16Array)
- [`Uint16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint16Array)
- [`Int32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int32Array)
- [`Uint32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint32Array)
- [`Float32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float32Array)
- [`Float64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float64Array)
- [`DataView`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/DataView)
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `ArrayBufferView`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isTypedArray(value) ⇒ boolean
Determines if value is one of the [**TypedArray** element types](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray#typedarray_objects):
- [`Int8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int8Array)
- [`Uint8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)
- [`Uint8ClampedArray`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8ClampedArray)
- [`Int16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int16Array)
- [`Uint16Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint16Array)
- [`Int32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Int32Array)
- [`Uint32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint32Array)
- [`Float32Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float32Array)
- [`Float64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Float64Array)
- [`BigInt64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt64Array)
- [`BigUint64Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigUint64Array)
**Kind**: global function
**Returns**: boolean
- `true` if the value is one of the typed arrays; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isMap(value) ⇒ boolean
Determines whether the passed value is of type [`Map`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Map`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isMapIterator(value) ⇒ boolean
Determines whether the passed value is of type [`Map Iterator`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/@@iterator).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Map Iterator`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isSet(value) ⇒ boolean
Determines whether the passed value is of type [`Set`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Set`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isSetIterator(value) ⇒ boolean
Determines whether the passed value is of type [`Set Iterator`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set/@@iterator).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Set Iterator`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isWeakMap(value) ⇒ boolean
Determines whether the passed value is of type [`WeakMap`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WeakMap).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `WeakMap`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isWeakSet(value) ⇒ boolean
Determines whether the passed value is of type [`WeakSet`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WeakSet).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `WeakSet`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isArrayBuffer(value) ⇒ boolean
Determines whether the passed value is of type [`ArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `ArrayBuffer`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isSharedArrayBuffer(value) ⇒ boolean
Determines whether the passed value is of type [`SharedArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `SharedArrayBuffer`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isAnyArrayBuffer(value) ⇒ boolean
Determines whether the passed value is one of either [`ArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer)
or [`SharedArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer).
**Kind**: global function
**Returns**: boolean
- `true` if the value is one of the array buffers;
otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isDataView(value) ⇒ boolean
Determines whether the passed value is of type [`DataView`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/DataView).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `DataView`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isPromise(value) ⇒ boolean
Determines whether the passed value is of type [`Promise`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Promise`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isGeneratorObject(value) ⇒ boolean
Determines whether the passed value is actually a [`Generator`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Generator)
object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Generator`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isGeneratorFunction(value) ⇒ boolean
Determines whether the passed value is of type [`GeneratorFunction`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/GeneratorFunction).
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `GeneratorFunction`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isAsyncFunction(value) ⇒ boolean
Determines whether the passed value is of type [`AsyncFunction`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AsyncFunction).
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `AsyncFunction`; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isArgumentsObject(value) ⇒ boolean
Determines whether the passed value is actually an
[`arguments`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/arguments)
object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is an `arguments` object; otherwise,
`false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isBoxedPrimitive(value) ⇒ boolean
Determines whether the passed value is a primitive wrapped by its object
equivalent (a.k.a. "boxed"). Except for `null` and `undefined`, all primitive
values have object equivalents that wrap around the primitive values:
- [`Boolean`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Boolean)
- [`String`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)
- [`Number`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number)
- [`Symbol`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol)
- [`BigInt`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt)
**Kind**: global function
**Returns**: boolean
- `true` if the value is one of the boxed primitives;
otherwise, `false`.
**See**: https://developer.mozilla.org/en-US/docs/Glossary/Primitive#primitive_wrapper_objects_in_javascript
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isModuleNamespaceObject(value) ⇒ boolean
Determines whether the passed value is a `Module` namespace object.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a `Module`; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
#### isPrimitive(value) ⇒ boolean
Determines whether the passed value is of a [**primitive**](https://developer.mozilla.org/en-US/docs/Glossary/Primitive)
data type.
**Kind**: global function
**Returns**: boolean
- `true` if the value is a primitive; otherwise, `false`.
| Param | Type | Description |
| ----- | -------------------- | ------------------------ |
| value | unknown
| The value to be checked. |
---
### Contributing
Pull requests are welcome. For major changes, please open an issue first to
discuss what you would like to change. If for whatever reason you spot something
to fix but cannot patch it yourself, please [open an issue][].
### License
This project is licensed under either of
- [Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0)
- [MIT license](https://opensource.org/licenses/MIT)
at your option.
The [SPDX](https://spdx.dev) license identifier for this project is
`MIT OR Apache-2.0`.
---
### Show Your Support
If you like the project (or want to bookmark it) —
— [give it a star ⭐️][] — it will greatly encourage
us.
[conventional-commits-badge]: https://img.shields.io/badge/commit%20style-Conventional-%23fa6673?logoColor=white&logo= 'Commit Style: Conventional Commits'
[conventional-commits-url]: https://www.conventionalcommits.org 'Commit Style: Conventional Commits'
[give it a star ⭐️]: https://github.com/OpenINF/openinf-util-types/stargazers
[license-badge--shields]: https://img.shields.io/badge/license-MIT%2FApache--2.0-blue.svg?logo=github 'License: MIT/Apache 2.0'
[license-badge-url]: #license 'License: MIT/Apache 2.0'
[matrix-badge--shields]: https://img.shields.io/badge/matrix-join%20chat-%2346BC99?logo=matrix 'Chat on Matrix'
[matrix-url]: https://matrix.to/#/#openinf-space:matrix.org 'You're invited to talk on Matrix'
[npm-badge--shields]: https://img.shields.io/npm/v/@openinf/util-types/latest.svg?logo=npm&color=fe7d37 'View on npm'
[npm-badge-url]: https://www.npmjs.com/package/@openinf/util-types#top 'View on npm'
[open an issue]: https://github.com/OpenINF/openinf-util-types/issues
[prettier-badge]: https://img.shields.io/badge/code_style-Prettier-ff69b4.svg?logo=prettier 'Code Style: Prettier'
[prettier-url]: https://prettier.io/playground 'Code Style: Prettier'
[project-status-badge]: https://img.shields.io/badge/project%20status-under%20construction-orange 'Project Status: Under construction badge'