Check if a value is an Error instance.
This is like value instanceof Error except it works across realms, such as
iframes or Node.js vm.
import isErrorInstance from 'is-error-instance'
isErrorInstance(new Error('')) // true
isErrorInstance('') // false
const CrossRealmError = vm.runInNewContext('Error')
isErrorInstance(new CrossRealmError('')) // true
isErrorInstance(new TypeError('')) // true
isErrorInstance(new AnyOtherError('')) // true
isErrorInstance(new DOMException('')) // true
isErrorInstance(new DOMError('')) // true
isErrorInstance(new Proxy(new Error(''), {})) // true
isErrorInstance(
new Proxy(new Error(''), {
getPrototypeOf: () => {
throw new Error('')
},
}),
) // falsenpm install is-error-instanceThis package works in both Node.js >=18.18.0 and browsers.
This is an ES module. It must be loaded using
an import or import() statement,
not require(). If TypeScript is used, it must be configured to
output ES modules,
not CommonJS.
value any
Return value: boolean
modern-errors: Handle errors in a simple, stable, consistent wayerror-custom-class: Create one error classerror-class-utils: Utilities to properly create error classeserror-serializer: Convert errors to/from plain objectsmerge-error-cause: Merge an error with itscausenormalize-exception: Normalize exceptions/errorsset-error-class: Properly update an error's classset-error-message: Properly update an error's messagewrap-error-message: Properly wrap an error's messageset-error-props: Properly update an error's propertiesset-error-stack: Properly update an error's stackerror-cause-polyfill: Polyfillerror.causehandle-cli-error: 💣 Error handler for CLI applications 💥beautiful-error: Prettify error messages and stackslog-process-errors: Show some ❤ to Node.js process errorserror-http-response: Create HTTP error responseswinston-error-format: Log errors with Winston
For any question, don't hesitate to submit an issue on GitHub.
Everyone is welcome regardless of personal background. We enforce a Code of conduct in order to promote a positive and inclusive environment.
This project was made with ❤️. The simplest way to give back is by starring and sharing it online.
If the documentation is unclear or has a typo, please click on the page's Edit
button (pencil icon) and suggest a correction.
If you would like to help us fix a bug or add a new feature, please check our guidelines. Pull requests are welcome!