我将此小部件附加到Scaffold
正文。小部件获取一个返回json对象的async
方法。
我想从该json对象动态构建一个列表。问题是屏幕是空的..出于某种原因,当列表准备好或类似的时候,这个小部件需要刷新自己。
有什么想法吗?
class TestList extends StatelessWidget {
final quiz;
TestList({this.quiz});
@override
Widget build(BuildContext context) {
var listArray = [];
this.quiz.then((List value) { // this is a json object
// loop through the json object
for (var i = 0; i < value.length; i++) {
// add the ListTile to an array
listArray.add(new ListTile(title: new Text(value[i].name));
}
});
return new Container(
child: new ListView(
children: listArray // add the list here.
));
}
}
答案 0 :(得分:9)
您可以使用setState
重建用户界面。
示例:
class TestList extends StatefulWidget {
final Future<List> quiz;
TestList({this.quiz});
@override
_TestListState createState() => new _TestListState();
}
class _TestListState extends State<TestList> {
bool loading = true;
_TestListState(){
widget.quiz.then((List value) {
// loop through the json object
for (var i = 0; i < value.length; i++) {
// add the ListTile to an array
listArray.add(new ListTile(title: new Text(value[i].name));
}
//use setState to refresh UI
setState((){
loading = false;
});
});
}
@override
Widget build(BuildContext context) {
List<Widget> listArray = [];
return new Container(
child: new ListView(
children: loading?[]:listArray // when the state of loading changes from true to false, it'll force this widget to reload
));
}
}
答案 1 :(得分:4)
您可以使用FutureBuilder来帮助处理窗口小部件状态:
new FutureBuilder<List>(
future: widget.quiz,
builder:
(BuildContext context, AsyncSnapshot<List> snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.none:
return new Text('Waiting to start');
case ConnectionState.waiting:
return new Text('Loading...');
default:
if (snapshot.hasError) {
return new Text('Error: ${snapshot.error}');
} else {
return new ListView.builder(
itemBuilder: (context, index) =>
new Text(snapshot.data[index].name),
itemCount: snapshot.data.length);
}
}
},
)
基本上,它会根据将来的状态通知构建器上指定的方法。一旦未来收到一个值并且不是错误,您可以使用ListView.builder来创建列表,这是一种在所有项目属于同一类型时创建列表的便捷方法。
https://docs.flutter.io/flutter/widgets/FutureBuilder-class.html
的更多信息