在futurebuilder中访问多个期货的结果

时间:2020-05-26 14:47:26

标签: flutter dart future builder

我非常陌生,需要帮助。

我正在Future Builder中运行期货,然后尝试访问文档。不幸的是,我在下面遇到错误,代码和错误。如何访问两个不同的文档快照?我将来的方法应该返回什么吗?有一个更好的方法吗?

错误在这里:

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': (
        'dotted.path.to.QueryParamAuthentication'
    ),
    # rest of your DRF settings...

}

代码:

snapshot.data[1].data[index].data["fname"]

日志/错误:

class PostsWidget extends StatefulWidget {

@override
  _PostsWidgetState createState() => _PostsWidgetState();
}

class _PostsWidgetState extends State<PostsWidget> {
  Future getPosts() async {
    var firestore = Firestore.instance;
    QuerySnapshot qn = await firestore.collection("posts").getDocuments();
    return qn.documents;
  }

  Future getUsers() async {
    var firestore = Firestore.instance;
    QuerySnapshot qn = await firestore.collection("users").getDocuments();
    return qn.documents;
  }

  @override
  Widget build(BuildContext context) {
    return Container(
      child: FutureBuilder(
        future: Future.wait([getPosts(), getUsers()]),
        builder: (_, snapshot) {
          switch (snapshot.connectionState) {
            case ConnectionState.waiting:
              return Center(child: CircularProgressIndicator());
            default:
              return ListView.builder(
                itemCount: snapshot.data[0].length,
                itemBuilder: (_, index) {
                  return Card(
                      child: Column(
                    children: <Widget>[
                      Container(
                        color: Color(0xff707070),
                        child: Padding(
                          padding: const EdgeInsets.all(4.0),
                          child: Row(
                            mainAxisAlignment: MainAxisAlignment.spaceBetween,
                            children: <Widget>[
                              Padding(
                                padding: const EdgeInsets.all(4.0),
                                child: Text(
                                  snapshot.data[1].data[index].data["fname"],
                                  style: TextStyle(color: Colors.white),
                                ),
                              ),
                              Padding(
                                padding: const EdgeInsets.all(4.0),
                                child: Icon(
                                  Icons.info,
                                  color: Colors.white,
                                ),
                              ),
                            ],
                          ),
                        ),
                      )
                    ],
                  ));
                },
              );
          }
        },
      ),
    );
  }
}

1 个答案:

答案 0 :(得分:0)

snapshot.data[1].data[index].data["fname"]

这一行应该是:

snapshot.data[1][index].fname

其中 fname 是您正在访问的对象的属性。