我试图在我的数据库中显示一个名为ListView的数据,名为“练习”:
import 'package:flutter/material.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_core/firebase_core.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
runApp(MyApp());
}
class MyApp extends StatelessWidget {
final db = FirebaseFirestore.instance;
@override
Widget build(BuildContext context) {
return Scaffold(
body: StreamBuilder<QuerySnapshot>(
stream: db.collection('Exercises').snapshots(),
builder: (context, snapshot) {
if (!snapshot.hasData) {
return Center(
child: CircularProgressIndicator(),
);
} else
return ListView(
children: (snapshot.data! as QuerySnapshot).docs.map((doc) {
return Card(
child: ListTile(
title: Text(doc.data()['name']),
),
);
}).toList(),
);
},
),
);
}
}
但是,当我这样做时,我在我的应用程序中得到了错误:误差图像
谢谢你的帮助
发布于 2022-01-12 02:55:43
不能直接在脚手架中使用StreamBuilder,添加列或SinglechildScrollview或容器。
import 'package:flutter/material.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_core/firebase_core.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
runApp(MyApp());
}
class MyApp extends StatelessWidget {
final db = FirebaseFirestore.instance;
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column( // Column, Singlechild Scroll view Here
children: [
StreamBuilder<QuerySnapshot>(
stream: db.collection('Exercises').snapshots(),
builder: (context, snapshot) {
if (!snapshot.hasData) {
return Center(
child: CircularProgressIndicator(),
);
} else
return ListView(
children: (snapshot.data! as QuerySnapshot).docs.map((doc) {
return Card(
child: ListTile(
title: Text(doc.data()['name']),
),
);
}).toList(),
);
},
),
],
),
);
}
}
发布于 2022-01-12 03:12:46
首先,谢谢你的回答。我尝试过使用列和SinglechildScrollview,但是我得到了另一个错误,即MediaQuery Widget丢失了
https://stackoverflow.com/questions/70679688
复制相似问题