React Native: Working with Error Boundaries
How to integrate and test error boundaries to gracefully contain errors in React Native apps
Error boundaries act as fallback UI when errors occur
When used with React Native, error boundaries allow you to implement fallback screens at certain points in your app that will be displayed when a JavaScript error occurs at runtime as a means to notify the user something went wrong. These fallback screens can then give the user a friendly explanation that something indeed went wrong, as well as an opportunity to restart the app or reset the UX to a previous state.
The following screencast demonstrates an error boundary in action simulated from a development build of an app I personally develop. This error boundary wraps the entire app and therefore responds to errors originating from any component in the hierarchy. An exception is thrown when I switch from the Settings tab to the Plans tab. This results in the fallback UI — defined in an ErrorBoundary
component — being displayed. From here, the user can tap a button to restart the app, that also deletes user settings and other persisted state that may have caused the error: