使用StreamBuilder来获取Firestore文档,该文档包含Flutter中的地图列表

时间:2020-06-30 14:07:34

标签: flutter dart google-cloud-firestore

我要从我的firestore集合中读取以下格式的数据

enter image description here

这是下面的课程。不知道如何使用streamBuilder来阅读文档。我还希望我可以将选定的订单传递给下一页。预先感谢。

class OrderModel2 {
  final String uid;
  final int subTotal;
  final String address;
  final String address2;
  final String zipCode;
  final String phoneNumber;
  final dynamic timeCreated;
  final String status;
  final List<OrdersList> orders;

  OrderModel2(
      {this.timeCreated,
      this.status,
      this.subTotal,
      this.phoneNumber,
      this.zipCode,
      this.uid,
      this.address2,
      this.orders,
      this.address});

  OrderModel2.fromMap(Map<String, dynamic> data, String uid)
      : subTotal = data['subTotal'],
        address = data['address'],
        zipCode = data['zipCode'],
        phoneNumber = data['phoneNumber'],
        address2 = data['address2'],
        timeCreated = data['timeCreated'],
        status = data['status'],
        orders = data['orders'],
        uid = uid;
}

class OrdersList {
  final String productName;
  final String selected;
  final String image;
  final int price;
  final String category;

  OrdersList(
      {this.productName, this.selected, this.image, this.price, this.category});
  OrdersList.fromMap(Map<dynamic, dynamic> data)
      : productName = data['productName'],
        selected = data['selected'],
        image = data['image1'],
        price = data['newPrice'],
        category = data['category'];
}

1 个答案:

答案 0 :(得分:2)

这是您使用SteamBuilder访问“订单集合”中的文档的方式。

StreamBuilder<QuerySnapshot>(
  stream: Firestore.instance.collection('Orders').snapshots(),
  builder: (
    BuildContext context,
    AsyncSnapshot<QuerySnapshot> snapshot,
    ) {
  if (!snapshot.hasData) return new Text('Loading...');
  body: StreamBuilder<QuerySnapshot>(
    stream: Firestore.instance.collection("products").snapshots(),
    builder: (context, snapshot) {
      return !snapshot.hasData
          ? Center(child: CircularProgressIndicator())
          : ListView.builder(
              itemCount: snapshot.data.documents.length,
              itemBuilder: (context, index) {
                DocumentSnapshot data = snapshot.data.documents[index];
                return YourObject(
                  documentSnapshot: data,
                  paramI: data.documentID,
                  paramField: data['field'],
                );
              },
            );

一定要读这篇文章,以了解发生的一切! https://medium.com/flutterdevs/using-firebase-firestore-in-flutter-b0ea2c62bc7

这也是关于添加搜索字段的StackOverflow! Adding SearchField to StreamBuilder Reading from Firestore