首页 > 解决方案 > Flutter Firebase 查询 - 在文本小部件中显示设置值

问题描述

我有一个简单的FutureBuilder地方,我从查询中检索 Firestore 数据。我正在返回一个 QuerySnapshot。在同一个查询中,我从每个文档中更新一个“SUM”变量。但是如何使用这个 SUM 变量在文本小部件中显示?由于它是一个异步调用,因此该值不会更新。如果我setState在 firebase 查询中使用,该值会不断添加而不会停止。

我在状态下初始化了 Sum 变量:

 double sum = 0.0;

典型的 FutureBuilder 调用查询函数。这是我的查询:

Future<QuerySnapshot> getItems() async {

    var snapshot = await  FirebaseFirestore.instance
          .collection('Items')
          .where('time', isGreaterThan: _startofDay)
          .where('type', isEqualTo: 'food')
          .orderBy('time', descending: false)
          .get().then((value) {
            value.docs.forEach((element) {
              sum += element['price'];
            });
            return value;
     });
 }

我不想使用另一个运行相同查询并返回 Sum Value 的 FutureBuilder,因为我想最小化我的 firebase 文档读取。我只想在文本小部件中显示 Sum 值。有什么办法可以做到这一点?

标签: flutterdart

解决方案


Future<QuerySnapshot> getItems() async {

    var snapshot = await  FirebaseFirestore.instance
          .collection('Items')
          .where('time', isGreaterThan: _startofDay)
          .where('type', isEqualTo: 'food')
          .orderBy('time', descending: false)
          .get().then((value) {

            // set sum value as 0 before for each
            setState(() => sum = 0);

            value.docs.forEach((element) {

               // then count sum value again
               setState(() => sum += element['price']);
            });
            return value;
     });
 }

推荐阅读