Errors
Superstruct throws detailed errors when data is invalid, so that you can build extremely precise errors of your own to give your end users the best possible experience.
StructError
StructError
Error
The error class that Superstruct uses for its validation errors. This is exposed primarily as a convenience for checking whether thrown errors are an instanceof
the StructError
class.
Error Properties
Each error thrown includes the following properties:
Property | Type | Example | Description |
|
|
| An array of the values being validated at every layer. The first element in the array is the root value, and the last element is the current value that failed. This allows you to inspect the entire validation tree. |
|
|
| All the validation failures that were encountered. The error object always represents the first failure, but you can write more complex logic involving other failures if you need to. |
|
| The key of the value when validating complex values like objects, arrays, etc. | |
|
|
| The path to the invalid value relative to the root value. |
|
|
| The expected type of the invalid value. This is a string of the struct that failed validation (eg. |
|
|
| The invalid value. |
|
|
| If a custom message is specified, the original one will be preserved in this property (complies with standard). |
### Multiple Errors |
The error thrown by Superstruct is always the first validation failure that was encountered, because this makes for convenient and simple logic in the majority of cases. However, the failures
property is available with a list of all of the validation failures that occurred in case you want to add support for multiple error handling.
Last updated