Прослушайте две коллекции в базе данных firestore от флаттера

Я пытался прослушать два разных документа коллекции. Один показан ниже. Он в основном записывает данные в реальном времени на экран. Я хочу прослушать и другую коллекцию, но вместо этого выполнить определенную функцию. Как мне поступить, пожалуйста? Очень ценю любую помощь!

Expanded(
                      child: StreamBuilder(
                        stream:
                        FirebaseFirestore.instance.collection('location').snapshots(),
                        builder: (context, AsyncSnapshot<QuerySnapshot> snapshot) {
                          if (!snapshot.hasData) {
                            return Center(child: CircularProgressIndicator());
                          }
                          return ListView.builder(
                              itemCount: snapshot.data?.docs.length,
                              itemBuilder: (context, index) {
                                return ListTile(
                                  title:
                                  Text(snapshot.data!.docs[index]['name'].toString()),
                                  subtitle: Row(
                                    children: [
                                      Text(snapshot.data!.docs[index]['latitude']
                                          .toString()),
                                      SizedBox(
                                        width: 20,
                                      ),
                                      Text(snapshot.data!.docs[index]['longitude']
                                          .toString()),
                                    ],
                                  ),
                                  trailing: IconButton(
                                    icon: Icon(Icons.directions),
                                    onPressed: () {
                                      Navigator.of(context).push(MaterialPageRoute(
                                          builder: (context) =>
                                              MyMap(snapshot.data!.docs[index].id)));
                                    },
                                  ),
                                );
                              });
                        },
                      )),
3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
1
0
24
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы можете слушать другие коллекции firebase и вызывать свои функции следующим образом.

FirebaseFirestore.instance
    .collection('location')
    .snapshots()
    .listen((QuerySnapshot querySnapshot) {

  final  firestoreList = querySnapshot.docs;
  print(firestoreList.first.data());

}).onError((e) => print(e));

Это дает мне следующую ошибку: Тип аргумента «void Function (DocumentSnapshot <Object?>)» не может быть назначен типу параметра «void Function (QuerySnapshot <Map <String, dynamic>>)?»

Carl 23.04.2022 09:13

Я отредактировал свой ответ, пожалуйста, проверьте. Это будет работать сейчас

Kishan Busa 23.04.2022 09:22

Добро пожаловать, если это сработало, пожалуйста, примите этот ответ и проголосуйте, пожалуйста. Благодарю вас!

Kishan Busa 23.04.2022 09:38

У меня недостаточно репутации, чтобы проголосовать :(( но большое спасибо

Carl 23.04.2022 10:45

Другие вопросы по теме