When you started work on Flutter application screen design. You definitely face a red screen that shows UI error. It is most irritating and makes us unhappy when you are a beginner.
In Flutter, it’s important to understand how your user experiences these bugs and where those bugs occur. How we can find the bugs with the highest impact and work to fix them. Sometimes, it's necessary to show a meaningful message to make it more sensible for the tester and developer. Flutter framework provides us customization feature to handle these error widget. According to the docs, Flutter shows red screen error whenever a widget fails to build. There is a performRebuild() method inside of StatefulWidget.dart class that invoke to build the widget.
As we can see, the red screen error is nothing but a widget named ErrorWidget provided by the framework. The ErrorWidget will be invoked only when a widget building fails. When widget building fails, Error Widget replaces with your widget. That’s why it's visible only in the area occupied by the widget that has failed to build.
In this post, We going to create a custom red screen error message for a particular case. We'll display red screen error without being depended on widget building fails. We'll display a user-friendly error page instead of showing red exception. The final output will look lie below:
As you can see above, when we enter developerlibs text. It's working fine but when we not entered any text and pushing login button. It's showing red screen error. So, let's create this example with the help of following steps.
Creating a new Project
1. Create a new project from File ⇒ New Flutter Project with your development IDE.
2. After that open main.dart file and edit it. As we have set our theme and change debug banner property of Application. Now define a method onError which accepts a message string as a parameter. Call setState() to set the _errorMessage field and add a condition to build() method to show ErrorWidget when _errorMessage is not null. Here, if _errorMessage is null ErrorWidget is returned else MaterialApp will be returned.
to track and manage build method error. We have created a key by using the global key. The Global key will uniquely identify elements across the entire app.
3. Now, create a landing screen of an example where we'll display a text field to enter some text and button for the move to another screen as shown above.
as you can see _showSecondPage method. Here, we checking enter text value and showing red screen widget if the user does not enter any text.
4. Here, we have the second screen of the example where we simply displaying text that send from the landing screen.
Now, merge all files and run the example. You can see the app running very smoothly as shown above. But if you are facing any problem or you have any quires, please feel free to ask it from below comment section.
In Flutter, it’s important to understand how your user experiences these bugs and where those bugs occur. How we can find the bugs with the highest impact and work to fix them. Sometimes, it's necessary to show a meaningful message to make it more sensible for the tester and developer. Flutter framework provides us customization feature to handle these error widget. According to the docs, Flutter shows red screen error whenever a widget fails to build. There is a performRebuild() method inside of StatefulWidget.dart class that invoke to build the widget.
As we can see, the red screen error is nothing but a widget named ErrorWidget provided by the framework. The ErrorWidget will be invoked only when a widget building fails. When widget building fails, Error Widget replaces with your widget. That’s why it's visible only in the area occupied by the widget that has failed to build.
In this post, We going to create a custom red screen error message for a particular case. We'll display red screen error without being depended on widget building fails. We'll display a user-friendly error page instead of showing red exception. The final output will look lie below:
As you can see above, when we enter developerlibs text. It's working fine but when we not entered any text and pushing login button. It's showing red screen error. So, let's create this example with the help of following steps.
Creating a new Project
1. Create a new project from File ⇒ New Flutter Project with your development IDE.
2. After that open main.dart file and edit it. As we have set our theme and change debug banner property of Application. Now define a method onError which accepts a message string as a parameter. Call setState() to set the _errorMessage field and add a condition to build() method to show ErrorWidget when _errorMessage is not null. Here, if _errorMessage is null ErrorWidget is returned else MaterialApp will be returned.
to track and manage build method error. We have created a key by using the global key. The Global key will uniquely identify elements across the entire app.
3. Now, create a landing screen of an example where we'll display a text field to enter some text and button for the move to another screen as shown above.
as you can see _showSecondPage method. Here, we checking enter text value and showing red screen widget if the user does not enter any text.
4. Here, we have the second screen of the example where we simply displaying text that send from the landing screen.
Now, merge all files and run the example. You can see the app running very smoothly as shown above. But if you are facing any problem or you have any quires, please feel free to ask it from below comment section.