firebase - Firebase Cloud Firestore 在 Flutter 中获取地图数组
问题描述
我正在尝试使用 Firebase Cloud Firestore 作为我的数据库在 Flutter 中构建一些东西。我有一个集合('学生'),其中包含每个学生的文档。
在每个学生文档中都有一个数组,其中包含学生的分数图。见下文。
在 Flutter 中,我有以下课程:
class Student {
final String name;
final String subject;
final List<Mark> marks;
Student({this.name, this.subject, this.marks});
}
class Mark {
final int mark;
final String grade;
final String markedBy;
final String feedback;
Mark({this.mark, this.grade, this.markedBy, this.feedback});
}
我正在使用 Provider 流检索数据,如下所示:
Stream<List<Student>> get firebaseStudents {
return Firestore.instance.collection('students').snapshots().map(_firebaseStudentsFromSnapshot);
}
List<Student> _firebaseStudentsFromSnapshot(QuerySnapshot snapshot) {
return snapshot.documents.map((doc) {
return Student(
name: doc.data['name'] ?? '',
subject: doc.data['subject'] ?? '',
//trying to figure out how to map the marks!
);
}).toList();
}
如果我打印 doc.data['grades'] 我可以看到它是一个包含数据的地图数组,我只是不确定如何将其映射到 Mark 类的列表。
我环顾四周,看到了诸如使用 fromMap 之类的建议,但似乎无法使其正常工作。我已经尝试过以下方法(在 Mark 类中):
Mark.fromMap(Map<String,dynamic> map) :
mark = map['mark'],
grade = map['grade'],
markedBy = map['markedBy'],
feedback = map['feedback'];
并在数据库中检索:
marks: List<Mark>.from(doc.data['grades'].map((item) {
return new Mark(
mark: item['mark'],
grade: item['grade'],
markedBy = item['markedBy'],
feedback = map['feedback']
);
})),
但无济于事。我确定我只是错过了一个关键部分,但我对此仍然很陌生,所以我正努力解决所有这些问题。
提前感谢您的任何帮助或建议。
编辑
最终想出了一些可行的方法,但总是很高兴听到是否有更好的方法来做到这一点。
我认为使用 fromMap 可能有一种更聪明的方法,但目前类型差异给我带来了问题,但会看看我是否可以让它工作,因为这样会更整洁一些。
List<Student> _firebaseStudentsFromSnapshot(QuerySnapshot snapshot) {
return snapshot.documents.map((doc) {
List<Mark> marks = [];
List<dynamic> markMap = doc.data['grades'];
markMap.forEach((element) {
marks.add(new Mark(
mark = element['mark'],
grade = element['grade'],
markedBy = element['markedBy'],
feedback = element['feedback'];
));
});
return Student(
name: doc.data['name'] ?? '',
subject: doc.data['subject'] ?? '',
marks: marks,
);
}).toList();
}
解决方案
最终自己找到了解决方案,不确定它是否是最好的,但它对我有用。
List<Student> _firebaseStudentsFromSnapshot(QuerySnapshot snapshot) {
return snapshot.documents.map((doc) {
List<Mark> marks = [];
List<dynamic> markMap = doc.data['grades'];
markMap.forEach((element) {
marks.add(new Mark(
mark = element['mark'],
grade = element['grade'],
markedBy = element['markedBy'],
feedback = element['feedback'];
));
});
return Student(
name: doc.data['name'] ?? '',
subject: doc.data['subject'] ?? '',
marks: marks,
);
}).toList();
}