如何将子集合转换为带有flutter和firestore的列表?

时间:2018-11-04 14:48:01

标签: firebase dart flutter google-cloud-firestore

我有一个对象Dish,其中包含成分列表,我想获取它们。我能怎么做? 在Firebase中,“菜”是一个文档,“成分”是一个子集合。我试过了,但是没用。

class Dish{

  String name;
  DocumentReference reference;
  List<Ingredient> ingredients;

  Dish.fromMap(Map<String, dynamic> map, {this.reference}){
    this.name = map['name'];

    this
        .reference
        .collection("ingredients")
        .snapshots()
        .listen((QuerySnapshot snap) {
      final List<DocumentSnapshot> ingredientsDocuments = snap.documents;
      List<Ingredient> ing = [];
      for (var i = 0; i < ingredientsDocuments.length; i++) {
        ing.add(Ingredient.fromSnapshot(ingredientsDocuments[i]));
      }
      this.ingredients = ing;
    });
  }



  Dish.fromSnapshot(DocumentSnapshot snapshot)
      : this.fromMap(snapshot.data, reference: snapshot.reference);

  @override
  String toString() => "Dish<$String>";

}

class Ingredient{
  final String name;
  final DocumentReference reference;

  Ingredient.fromMap(Map<String, dynamic> map, {this.reference})
      : assert(map['name'] != null),
        name = map['name'];

  Ingredient.fromSnapshot(DocumentSnapshot snapshot)
      : this.fromMap(snapshot.data, reference: snapshot.reference);

  @override
  String toString() => "Ingredient<$String>";
}

1 个答案:

答案 0 :(得分:0)

您如何尝试使用Dish类从Firestore获取数据?您是否使用了任何异步任务(即Future)?在您的实施中什么不起作用?您收到任何错误吗?

由于我无法运行您提供的repro,因此您可以尝试以下示例代码。

List<Ingredient> ingredients;
// call getDocuments() to fetch data from Firestore and add it to the List
Future<void> getDocuments() async {
  ingredients = List();
 
  var collection = FirebaseFirestore.instance
      .collection('ingredients');
 
  collection.get().then((value) {
    value.docs.forEach((element) {
      setState(() {
        // add the object to the List
        ingredients.add(Ingredient(Ingredient.fromMap(element.data())));
      });
    });
  });
}

对于对象,可以如此简单。无需传递DocumentReference,因为我们将仅使用它来将数据映射到Object并能够将其添加到List中。

class Ingredients {
  var name;

  Ingredients(Ingredients document) {
    this.documentName = document.getName();
  }

  dynamic getName() => name;

  Ingredients.fromMap(Map<dynamic, dynamic> document)
      : name = document['name'];
}

您可以检查我在here中发布的工作示例。它添加了分页功能,但应该与我在此处共享的代码段具有类似的方法。