initState method
- @protected
- @mustCallSuper
Called when this object is inserted into the tree.
The framework will call this method exactly once for each State
object
it creates.
Override this method to perform initialization that depends on the location at which this object was inserted into the tree (i.e., context) or on the widget used to configure this object (i.e., widget).
If a State
's build method depends on an object that can itself
change state, for example a ChangeNotifier
or Stream
, or some
other object to which one can subscribe to receive notifications, then
be sure to subscribe and unsubscribe properly in initState,
didUpdateWidget, and dispose:
- In initState, subscribe to the object.
- In didUpdateWidget unsubscribe from the old object and subscribe to the new one if the updated widget configuration requires replacing the object.
- In dispose, unsubscribe from the object.
You cannot use BuildContext.dependOnInheritedWidgetOfExactType
from this
method. However, didChangeDependencies will be called immediately
following this method, and BuildContext.dependOnInheritedWidgetOfExactType
can
be used there.
If you override this, make sure your method starts with a call to super.initState().
Implementation
@protected
@mustCallSuper
void initState() {
assert(_debugLifecycleState == _StateLifecycle.created);
}