Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

typechecker

bevry606.7kArtistic-2.09.3.0TypeScript support: included

Utilities to get and check variable types (isString, isPlainObject, isRegExp, etc)

array, assert, assertion, async, async function, async-function, asyncFunction, bool, boolean, browser, check, check-type, checking, class, class-identifier, class-instance, compare, conventional class, conventional-class, conventionalClass, date, define-type, deno, deno-edition, deno-entry, denoland, empty, empty array, empty keys, empty map, empty plain object, empty-array, empty-keys, empty-map, empty-plain-object, emptyArray, emptyKeys, emptyMap, emptyPlainObject, error, es2022, es5, function, get object type, get type, get-object-type, get-type, getObjectType, getType, instanceof, is, is arguments, is array, is async, is async function, is bool, is boolean, is class, is conventional class, is date, is empty array, is empty keys, is empty map, is empty plain object, is empty weak map, is error, is function, is map, is native class, is null, is nullish, is number, is object, is plain object, is regexp, is string, is sync, is sync function, is undefined, is weak map, is-arguments, is-array, is-async, is-async-function, is-bool, is-boolean, is-class, is-conventional-class, is-date, is-empty-array, is-empty-keys, is-empty-map, is-empty-plain-object, is-empty-weak-map, is-error, is-function, is-map, is-native-class, is-null, is-nullish, is-number, is-object, is-plain-obj, is-plain-object, is-regexp, is-string, is-sync, is-sync-function, is-undefined, is-weak-map, isArguments, isArray, isAsyncFunction, isBool, isBoolean, isClass, isConventionalClass, isDate, isEmptyArray, isEmptyKeys, isEmptyMap, isEmptyPlainObject, isEmptyWeakMap, isError, isFunction, isMap, isNativeClass, isNull, isNullish, isNumber, isObject, isRegExp, isString, isSync, isSyncFunction, isUndefined, isWeakMap, javascript, javascript-type, keys, kind, map, module, native, native class, native-class, nativeClass, node, null, number, object, plain, plain object, plain objects, plain-object, plain-objects, plainObject, primitive, primitive-types, pure, regex, regexp, regular expression, simple, string, sync, syncFunction, test, type, type-check, type-checker, type-checking, typechecker, typed, typeguards, typeof, types, typescript, undefined, util, utility, validate, validation, vanilla, verify, weak map, weak-map, weakMap, what-type

readme

TypeChecker

Status of the GitHub Workflow: bevry NPM version NPM downloads
GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button
Discord server badge Twitch community badge

Utilities to get and check variable types (isString, isPlainObject, isRegExp, etc)

Why?

Why should I use this instead of say instanceof?

Under certain circumstances instanceof may not return the correct results. This occurs with node's vm module especially, and circumstances where an object's prototype has been dereferenced from the original. As such, for basic == and === checks (like a === null), you're fine not using this, but for checks when you would have done instanceof (like err instanceof Error), you should try to use this instead. Plus things like isPlainObject are darn useful!

Usage

Complete API Documentation.

Install

npm

  • Install: npm install --save typechecker
  • Import: import * as pkg from ('typechecker')
  • Require: const pkg = require('typechecker')

Deno

import * as pkg from 'https://unpkg.com/typechecker@^9.3.0/edition-deno/index.ts'

Skypack

<script type="module">
    import * as pkg from '//cdn.skypack.dev/typechecker@^9.3.0'
</script>

unpkg

<script type="module">
    import * as pkg from '//unpkg.com/typechecker@^9.3.0'
</script>

jspm

<script type="module">
    import * as pkg from '//dev.jspm.io/typechecker@9.3.0'
</script>

Editions

This package is published with the following editions:

  • typechecker aliases typechecker/index.cjs which uses the Editions Autoloader to automatically select the correct edition for the consumer's environment
  • typechecker/source/index.ts is TypeScript source code with Import for modules
  • typechecker/edition-browsers/index.js is TypeScript compiled against ES2022 for web browsers with Import for modules
  • typechecker/edition-es2022/index.js is TypeScript compiled against ES2022 for Node.js 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • typechecker/edition-es5/index.js is TypeScript compiled against ES5 for Node.js 4 || 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • typechecker/edition-es2022-esm/index.js is TypeScript compiled against ES2022 for Node.js 12 || 14 || 16 || 18 || 20 || 21 with Import for modules
  • typechecker/edition-types/index.d.ts is TypeScript compiled Types with Import for modules
  • typechecker/edition-deno/index.ts is TypeScript source code made to be compatible with Deno

History

Discover the release history by heading on over to the HISTORY.md file.

Backers

Code

Discover how to contribute via the CONTRIBUTING.md file.

Authors

Maintainers

Contributors

Finances

GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button

Sponsors

  • Andrew Nesbitt — Software engineer and researcher
  • Balsa — We're Balsa, and we're building tools for builders.
  • Codecov — Empower developers with tools to improve code quality and testing.
  • Poonacha Medappa
  • Rob Morris
  • Sentry — Real-time crash reporting for your web apps, mobile apps, and games.
  • Syntax — Syntax Podcast

Donors

License

Unless stated otherwise all works are:

and licensed under:

changelog

History

v9.3.0 2023 December 27

v9.2.0 2023 December 5

v9.1.0 2023 December 5

v9.0.0 2023 November 25

  • Type definitions now discriminate inputs and outputs, allowing TypeChecker to work natively with TypeScript narrowing
  • Updated dependencies, base files, and editions using boundation

v8.6.0 2023 November 25

v8.5.0 2023 November 21

v8.4.0 2023 November 21

v8.3.0 2023 November 20

v8.2.0 2023 November 14

v8.1.0 2023 November 13

v8.0.0 2023 November 13

v7.18.0 2021 August 1

v7.17.0 2020 October 29

v7.16.0 2020 September 5

v7.15.0 2020 September 4

v7.14.0 2020 August 18

v7.13.0 2020 August 4

v7.12.0 2020 July 23

v7.11.0 2020 June 25

v7.10.0 2020 June 25

v7.9.0 2020 June 22

v7.8.0 2020 June 21

v7.7.0 2020 June 20

v7.6.0 2020 June 11

v7.5.0 2020 June 10

v7.4.0 2020 May 22

v7.3.0 2020 May 21

v7.2.0 2020 May 21

v7.1.0 2020 May 21

v7.0.0 2020 May 11

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=8 to node: >=10 to keep up with mandatory ecosystem changes

v6.4.0 2020 May 1

v6.3.0 2019 December 10

v6.2.0 2019 December 6

v6.1.0 2019 December 6

v6.0.0 2019 December 6

  • Renamed isEmpty to isNullish
  • Renamed isEmptyObject to isEmptyKeys
  • Added isEmptyPlainObject, isEmptyArray, isEmptyMap, isEmptyWeakMap which will all throw if the passed value was not of the expected type
  • Updated dependencies, base files, and editions using boundation

v5.2.0 2019 December 1

v5.1.0 2019 December 1

v5.0.0 2019 November 18

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=0.8 to node: >=8 to keep up with mandatory ecosystem changes

v4.11.0 2019 November 18

v4.10.0 2019 November 18

v4.9.0 2019 November 13

v4.8.0 2019 November 8

v4.7.0 2018 December 7

v4.6.0 2018 September 8

  • Fixed the false positive of function(AnArgumentWithAnUpperCaseFirstLetter){} being detected as a class by isClass and isConventionalClass
  • Swapped flow type annotation with typescript jsdoc annotations
  • Updated base files and editions using boundation

v4.5.0 2018 February 17

  • asynchronous functions are now detected as functions, before there was no support for them
    • getType(async function () {}) now returns function
    • isFunction(async function () {}) returns true
    • isAsyncFunction(async function () {}) returns true
    • isSyncFunction(async function () {}) returns false
    • Thanks to David Kebler for issue #17

v4.4.1 2017 January 18

v4.4.0 2016 November 11

  • Use require over import
  • More efficient isObject check
    • Fixes isObject and isPlainObject not returning booleans in some cases
  • More comprehensive native vs conventional class tests
  • Updated base files
  • Updated dependencies

v4.3.0 2016 March 21

  • Removed getTypes as it was ambiguous, internal and no one external used it
  • Exposed typeMap which links types to the methods that check for them, used by getType

v4.2.1 2016 March 20

  • Fixed packing issue

v4.2.0 2016 March 20

  • Now defined as individual methods
  • Repackaged

v4.1.0 2016 January 15

  • Now defined as a class with static methods instead of an object with functions as that is essentially what it is
  • Repackaged

v4.0.1 2015 December 9

  • Updated base files
  • Updated dependencies

v4.0.0 2015 September 21

  • Added new map and weakmap types that the getType method can now return
  • Added the methods:
    • isMap (checks for Map instance)
    • isWeakMap (checks for WeakMap instance)

v3.0.0 2015 August 27

  • Added new class type that the getType method can now return
  • Added the methods:
    • isClass (checks for native and conventional classes)
    • isNativeClass (checks for native ES6 classes)
    • isConventionalClass (checks for functions that start with a capital letter)
  • Anonymous compiled/non-native classes may be detected as functions instead of as classes. If you rely on class detection, be aware of this, and document this to your users accordingly.

v2.1.0 2015 August 26

  • Fixed isEmpty - it use to return the opposite of what was empty
  • Converted from CoffeeScript to ES6+
  • Updated base files
  • Everything is now tested thoroughly

v2.0.8 2013 November 1

  • Dropped component.io and bower support, just use ender or browserify

v2.0.7 2013 October 27

  • Re-packaged

v2.0.6 2013 September 18

  • Fixed node release (since v2.0.5)
  • Fixed bower release (since v2.0.4)

v2.0.5 2013 September 18

  • Fixed node release (since v2.0.4)

v2.0.4 2013 September 18

  • Fixed cyclic dependency problem on windows (since v2.0.3)
  • Added bower support

v2.0.3 2013 September 18

  • Attempt at fixing circular dependency infinite loop (since v2.0.2)

v2.0.2 2013 September 18

  • Added component.io support

v2.0.1 2013 March 27

  • Fixed some package.json properties

v2.0.0 2013 March 27