#dart #flutter #google-cloud-firestore
#dart #flutter #google-облако-firestore
Вопрос:
Я извлекаю данные из коллекции «проигрывателей» в моем коде в проекте flutter. Прямо сейчас я создаю listview из данных, которые я получаю с помощью приведенного ниже кода. Однако я хотел бы получить еще некоторые данные, которые просто нужно было бы сохранить в фоновом режиме и не использовать визуально. Однако я не могу понять, как извлечь данные, не показывая их визуально с помощью виджета.
Я попытался использовать ту же процедуру, что и приведенный здесь код. Одновременно я могу извлекать только одну коллекцию, а не обе.
Может ли кто-нибудь указать мне, как извлекать данные без необходимости «показывать» их в виджете сборки?
Widget _buildBody(BuildContext context) {
return StreamBuilder<QuerySnapshot>(
stream: Firestore.instance.collection('Spillere').snapshots(),
builder: (context, snapshot) {
if (!snapshot.hasData) return LinearProgressIndicator();
return _buildList(context, snapshot.data.documents);
},
);
}
Widget _buildList(BuildContext context, List<DocumentSnapshot> snapshot) {
return ListView(
padding: const EdgeInsets.only(top: 10.0),
children: snapshot.map((data) => _buildListItem(context, data)).toList(),
);
}
Widget _buildListItem(BuildContext context, DocumentSnapshot data) {
final record = Record.fromSnapshot(data);
return Padding(
key: ValueKey(record.name),
padding: const EdgeInsets.all(5.0),
child: Container(
decoration: BoxDecoration(
border: Border.all(color: Colors.grey),
borderRadius: BorderRadius.circular(5.0),
),
child: ListTile(
title: Text(record.name ": " record.score.toString()),
trailing: new IconButton(icon: new Icon(isAdmin ? Icons.add : null, color: Colors.green),
onPressed: (){
if(isAdmin){
record.reference.updateData({'score': record.score 1});
}
}
),
),
),
);
}
Комментарии:
1. Похоже, вы пытаетесь отформатировать свой код, просто поставив пробелы перед первой строкой. Вместо этого лучше выделить весь фрагмент кода и использовать кнопку {} в редакторе для форматирования всего.
2. Ах, не знал. Будем делать это в будущем — Спасибо @DougStevenson