The controllers could be defined with more than way and be accessed directly from the controller class or from the XML file.
The simple way is by specifying the type and the name, and the extension will instantiate it for you:
<TextField controller="TextEditingController myTextEditingController" />
Or
<TextField controller="myTextEditingController = TextEditingController()" />
Another way is to define it within the controller class:
final myTextEditingController = new TextEditingController();
And you can access it in XML:
<TextField controller="ctrl.myTextEditingController" />
Sometimes you might need to access the instance of the State, for example, For AnimationControler to work properly, the current State (which inherets from SingleTickerProviderStateMixin
mixin) must be passed as parameter: AnimationController(vsync: this)
. for this case you can define it as a <var />
in the XML file as follow:
<MyPage controller="MyController">
<var name="animationController" type="AnimationController" value="AnimationController(vsync: this, duration: Duration(milliseconds: 300))" />
<!-- Or without `type` -->
<var name="animationController" value="AnimationController(vsync: this, duration: Duration(milliseconds: 300))" />
...
</MyPage>
NOTE The controllers defined using <var />
can be accessed within the controller after didLoad()
, not in the constructor:
@override
void didLoad() {
animationController.forward();
}