Properly update an error's class
npm install set-error-class






Properly update an error's class.
- Sets an error's
prototype, name and constructor
- Update the error's stack with its new name
- Handles invalid errors
``js
import setErrorClass from 'set-error-class'
const typeError = new TypeError('test')
console.log(typeError instanceof TypeError) // true
console.log(typeError.name) // 'TypeError'
console.log(typeError.constructor) // TypeError
console.log(typeError.stack) // TypeError: test ...
const rangeError = setErrorClass(typeError, RangeError)
console.log(rangeError === typeError) // true
console.log(rangeError instanceof RangeError) // true
console.log(rangeError.name) // 'RangeError'
console.log(rangeError.constructor) // RangeError
console.log(rangeError.stack) // RangeError: test ...
`
`bash`
npm install set-error-class
This 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.
error Error | unknown\ErrorClass typeof Error\Error
_Return value_:
Sets the error'sname
prototype,constructor
and.
error is returned. If error is not an Error instance, it is converted to
one.
In V8 (Chrome, Node.js, Deno, etc.),
error.stack
includes
error.name.
It is updated accordingly.
ErrorClass is assigned to error, but its constructor is not called. In someErrorClass
instances, this might lead to invalid errors. If 's constructor iserror
doing anything significant, that logic should be performed on as well.
- modern-errors: Handle errors in
a simple, stable, consistent way
- error-custom-class: Create
one error class
- error-class-utils: Utilities
to properly create error classes
- error-serializer: Convert
errors to/from plain objects
- normalize-exception:
Normalize exceptions/errors
- is-error-instance: Check if
a value is an Error instanceset-error-message
- : Properlywrap-error-message
update an error's message
- :set-error-props
Properly wrap an error's message
- : Properlyset-error-stack
update an error's properties
- : Properlymerge-error-cause
update an error's stack
- : Merge ancause
error with its error-cause-polyfill
- :error.cause
Polyfill handle-cli-error
- : 💣 Errorlog-process-errors
handler for CLI applications 💥
- : Showerror-http-response
some ❤ to Node.js process errors
- :winston-error-format
Create HTTP error responses
- : 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!