Error Boundaries in Blazor

Error Boundaries in Blazor

This blog is going to explain what is Error Boundary in Blazor and how to implement it in the application. The Error Boundary is an easy way to handle the exception. If there is no error it will render the content, otherwise it will display the error message. Wrapping error Error Boundary component around the content will handle the unhandled exception.

Let’s see this with an example.

The following is the Index.razor page. Here I have added the Counter component covered by the <ErrorBoundary> component.

Index.razor
@page "/"
 
<PageTitle>Index</PageTitle>
 
<h1>Hello, world!</h1>
 
Welcome to your new app.
 
<SurveyPrompt Title="How is Blazor working for you?" />
 
<ErrorBoundary>
<Counter />
</ErrorBoundary>

To demonstrate the error handling process. I have modified the existing IncrementCount() as follows. So when the user clicks the click me button it will throw out the exception.

private void IncrementCount()
{
  throw new Exception("Error Boundary Demo.");
}

The following image is the output of the code above. Here you can see that when the user clicks the button it shows an error message.

Error Boundaries in Blazor
Note:
The error message and alert icon comes from the default Balzor template.
You can change it to wwwroot\css\site.css file if you wish.

Custom Error Message

You can customize the error message using the Error Boundary. See the code snippets below. Two more components <ChildContent> and <ErrorContent> are added here. You can write your custom error message within <ErrorContent>.

<ErrorBoundary>
    <ChildContent>
        <Counter />
    </ChildContent>
    <ErrorContent>
        <div class="alert alert-danger">
            Oh No... There is an error...
        </div>
    </ErrorContent>
</ErrorBoundary>

The following image is an output of the above code.

Error Boundaries in Blazor

Also, you can catch the exact and detailed error using the context attribute of the ErrorBoundary component. In the below code snippets the Context=ex is added in the ErrorBoundary component.Therefore, it will display exception details.

<ErrorBoundary Context=ex>
    <ChildContent>
        <Counter />
    </ChildContent>
    <ErrorContent>
        <div class="alert alert-danger">
            Oh No... There is an error...
        </div>
        <div class="blazor-error-boundary">
           <div>@ex.Message</div>
           <div>@ex</div>
        </div>
    </ErrorContent>
</ErrorBoundary>

The below image is an output of the above code. It shows the complete error details.

Error Boundaries in Blazor

Error Boundary Recover Method

To set the non-error state, you can reset the status using the Recovery() method. For example, if an error occurs, the application will display the error. If the user fixes the error it will still show the error. To go non-error, you can use the Recover() method.

<ErrorBoundary Context=ex @ref="errorBoundary">
    <ChildContent>
        <Counter />
    </ChildContent>
    <ErrorContent>
        <div class="alert alert-danger">
            Oh No... There is an error...
        </div>
        <div class="blazor-error-boundary">
           <div>@ex.Message</div>
           <div>@ex</div>          
        </div>
        <div>
            <button class="btn btn-primary" @onclick="()=>errorBoundary?.Recover()">Recover</button>
        </div>
    </ErrorContent>
</ErrorBoundary>
 
@code {
    private ErrorBoundaryerrorBoundary;
}

The image below is the output of the code snippet above. After clicking the Click me, the application displays an error message. After the user clicks the Recovery button, the application will move to an non-error state.

Error Boundaries in Blazor

I hope this helps you. Keep coding.

Comments

Popular posts from this blog

Entity Framework Core (EF) with SQL Server LocalDB

Component Disposal in Blazor

Localization in ASP.NET Core MVC with Example