我试图创建一个自定义的有状态小部件。但是我找不到任何关于如何在构造函数上设置默认值的引用。
举个例子:
class CustomWidget extends StatefulWidget {
final String buttonText;
final Function onPressed;
CustomWidget({Key key, @required this.onPressed, this.buttonText}) : super(key: key);
@override
_CustomWidgetState createState() => _CustomWidgetState();
}
class _CustomWidgetState extends State<CustomWidget> {
@override
Widget build(BuildContext context) {
return FlatButton(
onPressed: widget.onPressed,
child: Text(widget.buttonText),
);
}
}
当我将小部件创建为另一个小部件的子部件并包含它完美运行的所有属性时child: CustomWidget(
buttonText: 'Text of the button',
onPressed: () {},
)
但是,当我离开 buttonText 时,应用程序崩溃了。child: CustomWidget(
onPressed: () {},
)
一个基本的解决方法是简单地添加行 buttonText: ''
.我并不总是想在创建每个自定义小部件的属性时专门解决它。所以我的问题是,如何在构造函数上设置默认属性?那么当我省略一个属性时,应用程序不会崩溃?
最佳答案
您的构造函数名称应该是类名称。要提供默认值,您只需添加 =defaultValue
在构造函数中的变量旁边。
class CustomWidget extends StatefulWidget {
final String buttonText;
final Function onPressed;
CustomWidget ({Key key, @required this.onPressed, this.buttonText = 'defaultString'}) :super(key: key);//this.buttonText='defaultString'
@override
_CustomWidgetState createState() => _CustomWidgetState();
}
关于class - Flutter Stateful Widget 设置构造函数默认值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63872217/