Basics of State Management in Flutter.

Maaz Aftab
CodeChai
5 min readFeb 7, 2020

--

In Flutter everything is a widget. A widget is mostly the Component on the Screen, like Text, Image, some List, or even screen. Below is the picture of some of the commonly used widgets

Moreover, widget has its State as well that is actually the data that is being used in building of widget, like a Text Widget may have a String data in the state of it to show that String on the screen.

Flutter Widget Rendered by Flutter on actual Screen Fig(b).

Flutter uses below equation fig(c) to render the widget on application screen. Where f is the build function of widget, which defines how the widget would look like, state is the current state of the widget, and UI is the actually output of widget on screen.

Flutter Widget Rendering Equation Fig(c)

However, once you define the widget and it is built, then you can not change the widget appearance fig(d). For an instance, you can not change the String in Text widget dynamically, since widgets are Immutable, i.e., Unchangeable.

Trying to change widget dynamically which is not possible Fig(d)

Though widgets are unchangeable fig(d), but widget’s state are mutable, changeable fig(e), these types of widget are called Stateful widget, and since Flutter is a declarative Framework, whenever the state of widget changes, the widget gets rendered again with the new state. So changing the widget’s state is indirectly same as changing the widget dynamically.

Changing widget state that is possible in Flutter Fig(e)

Flutter have two types of widgets Stateful widget, discussed above, and Stateless widget.

Stateful widget is the widget whose state is mutable, thus you can change the widget appearance dynamically by changing the state of widget. Changing the widget state fig(f).

setState()

In Stateful widget, whenever there is some change occurs in the state, we call setState() method, available inside the Stateful widget. Calling setState tells the Framework that the widget’s state is updated, and the widget should be rebuilt, hence it is rebuilt with the new state, see fig(f).

Changing the widget state by calling setState() Fig(f)

Flutter uses below equation to render widget, and if there is some change in state of widget, then again it uses same equation and same build function, which defines how widget would look like, but with new state value to draw updated UI on screen.

Flutter Widget Building equation with new state value Fig(g)

On the other hand, Stateless widget is a widget whose state is immutable, thus you can not change the widget appearance dynamically in any way. So, they are used when we have static widget.

State types.

Now if we make a Stateful widget, its state is only available to the widget itself. however, sometimes it is essential to have a common state between different widgets so that different widgets can use the same state data at the same time.

Let’s consider a short scenario. Say, if we are making cart application in which user can select products from the application and add it to cart, and once He completes his shopping, he can navigate to the Checkout screen so that he can know and pay the bill.

Cart Application State-Widget Diagram, Saving Cart in Cart Screen Widget State Fig(h)

Now as you can see fig(h), the cart, which is a list of selected products, is in the state of Cart Screen widget, local to the widget. Now this Cart that is in the state of Cart Screen widget is not available in the Checkout Screen widget, however, we need Cart in the Checkout Screen as well for the calculation and making of bill.

To solve this, we lift the state up to a widget which is the ancestor widget of all the widgets that are using that common state fig(i). This technique is called Lifting the state up.

Cart Application State-Widget Diagram, Saving Cart in Parent Widget State Fig(i)

The State which is local to a widget or define in widget itself called Ephemeral State and the State which is common to different widgets called Global State or App State.

So, State Management is all about managing the state, deciding which widget’s state needs to be mutable (Stateful widget), and which needs to be immutable (Stateless Widget). Calling setState whenever there is a change in the state of widget, and deciding where to put state either in widget itself or in common ancestor widget.

That’s the basics of State Management that you must learn and implement in order to master the art of State Management, because every advance state management like Provider , BLoC, or Redux, all implements, behind the scene, the same thing, which we have discussed above.

If you want to learn the implementation of State Management either Basic or some advance, then you can head over to my YouTube channel Easy Approach that mainly covers Flutter development, and has over 100 videos on Flutter.

Thank you!

--

--

Maaz Aftab
CodeChai

Founder Of Easy Approach, Flutter Lover, YouTuber, and a writer.