如何在Flutter中构建动态列表?

时间:2017-12-15 06:13:29

标签: listview asynchronous flutter

我将此小部件附加到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.
    ));
  }
}

2 个答案:

答案 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

的更多信息