Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dillonchanis/vue-error-boundary

A reusable error boundary component for catching JavaScript errors and displaying fallback UIs.
https://github.com/dillonchanis/vue-error-boundary

error-handling frontend javascript vue

Last synced: 6 days ago
JSON representation

A reusable error boundary component for catching JavaScript errors and displaying fallback UIs.

Awesome Lists containing this project

README

        

# vue-error-boundary

[![NPM version](https://img.shields.io/npm/v/vue-error-boundary.svg?style=for-the-badge&colorA=BEC8BE&colorB=47B784)](https://www.npmjs.com/package/vue-error-boundary)

A reusable error boundary component for catching JavaScript errors and displaying fallback UIs.

The ErrorBoundary component is based on [React's example component](https://reactjs.org/blog/2017/07/26/error-handling-in-react-16.html).

**Requires Vue3**

## Install

```bash
yarn add vue-error-boundary

npm i vue-error-boundary --save
```

## Usage

To use this component simply wrap any other component which may throw an Error. Errors thrown in child components will automatically bubble up to the `VErrorBoundary` component.

```html

```

If you are using it inside a `v-for`, ensure to set the `stop-propagation` prop on your `VErrorBoundary` component.

```html



...


```

## Props

| Attribute | Description | Type | Required | Default |
|------------------|--------------|------|----------|---------|
| fall-back | Fallback component to render in case of error. | Component | `false` | DefaultFallback |
| on-error | Callback function to perform on error. | `Function` | `false` | `null` |
| params | Props to pass to your fall back component. | `Object` | `false` | `{}` |
| stop-propagation | Stop propagation of errors to other `errorCaptured` hooks. | `boolean` | `false` | `false` |

## Scoped Slots

| Property | Description | Type |
|----------|-------------|---------|
| error | The error | `Error` |
| hasError | Whether an error occurred. | `boolean` |
| info | Information on where the error was captured | `string` |

## How to Use

### Fallback UI via fall-back

We can provide a fallback UI to display via the `fall-back` prop. It simply takes a Vue component to render.

#### Basic Example

```html



import ProductErrorCard from '...'

export default {
// ...
data () {
return {
productError: ProductErrorCard
}
}
}

```

#### With Props

You can pass props to your fallback component through the `params` prop. `params` expects an object containing the data you wish to pass.

```html







import MyCustomFallbackComponent from '...'

export default {
data: () => ({
fallBack: MyCustomFallbackComponent,
contacts: [...]
})
}

```

Then in your custom fallback component:

```html


Could not render - {{ id }}

export default {
props: ['id'],
}

```

Furthermore, we can directly access the contents of the `VErrorBoundary` component's `errorCaptured` hook either through a callback or Vue's emit.

### Scoped Slots

If you do not wish to use a fallback component you can alternatively utilize scoped slots to present data in your current template.

#### Basic Example

```html


No error occurred.

Message to appear if error occurred.

```

## Events

### Callbacks via on-error

The `VErrorBoundary` can receive a callback function through the `on-error` prop.

```html

...

// ...
methods: {
handleError (err, vm, info) {
// do something
}
}
// ...

```

### @errorCaptured event

The callback function will receive the same parameters as the `errorCaptured` method.

We can also listen to a Vue event via an `errorCaptured` event.

```html

...

// ...
methods: {
handleError (err, vm, info) {
// do something
}
}
// ...

```

### Stop Propagation

The `errorCaptured` hook will continue to propagate errors up the component tree unless it returns `false`. Doing so will stop any additional `errorCaptured` hooks to execute **and** the global `errorHandler` from being invoked for the error. To do this we can use the `stop-propagation` prop.

```html

...

```

## Contributors

[wallyjue](https://github.com/wallyjue)