asynchronous - 如何在 Flutter 的 Firebase 快照上调用 Future?

标签 asynchronous stream async-await dart flutter

当我使用 StreamBuilder 返回一个快照时,我收到一个重复的错误,该错误只持续一两秒,上面写着“在 null 上调用快照”。我相信我需要让我的快照异步,但我可能完全错了。这是我的代码...

child: new StreamBuilder(
                        stream: fb.child('UserVideo/${fUser.uid}').orderByKey().onValue,
                        builder: (BuildContext context, AsyncSnapshot<Event> event) {
                          if (event.data.snapshot.value == null) {
                            return new Card(
                              child: new Center(
                                child: new Text('SEARCH',
                                    textAlign: TextAlign.center,
                                    style: new TextStyle(
                                        fontSize: 30.0,
                                        fontFamily: 'Chewy',
                                        color: Colors.black)),
                              ),
                            );
                          } else if (event.data.snapshot.value != null) {
                              Map unsorted =
                                  event.data.snapshot.value; //store each map

                              final myMap =
                              new SplayTreeMap<String, dynamic>.from(
                                  unsorted,
                                      (a, b) => unsorted[a]['rank']
                                      .compareTo(unsorted[b]['rank']));

                              //Map myMap = event.data.snapshot.value; //store each map
                              var titles = myMap.values;

                              List onesTitles = new List();
                              List onesIds = new List();
                              List onesImages = new List();
                              List onesRank = new List();

                              for (var items in titles) {
                                onesTitles.add(items['title']);
                                onesIds.add(items['videoID']);
                                onesImages.add(items['imageString']);
                                onesRank.add(items['rank'].toString());
                              }

                              names = onesTitles;
                              ids = onesIds;
                              numbers = onesRank;
                              vidImages = onesImages;

我正在将我的用户信息排列到列表中,然后从中填充卡片信息。

最佳答案

使用安全导航运算符应该可以防止该错误

event.data?.snapshot?.value

只有当前面的部分评估为 != null 时,它才会评估后续部分

关于asynchronous - 如何在 Flutter 的 Firebase 快照上调用 Future?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50310896/

相关文章:

java - Java Jersey 中的异步

c# - TCP套接字编程,读取数据时出现异常行为

c# - 个人等待与 Task.WhenAll

node.js - NodeJS,从async wait获取返回值

java - web.xml 中支持异步的目的是什么?

javascript - node.js 异步 waterfall 调用以前的方法

c# - 将流作为文件添加到 ISO

c# - 生产者/消费者,流缓冲问题

c# - Task.WaitAny() — 检查结果

winforms - 最佳实践 : Blocking execution while waiting for an Async method