我試圖顯示我在名為“練習”的 Cloud Firestore 資料庫中獲取的資料的 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(),
);
},
),
);
}
}
但是當我這樣做時,我的應用程式 中出現錯誤:錯誤影像
謝謝您的幫助
uj5u.com熱心網友回復:
不能直接使用 StreamBuilder 到腳手架,添加 Column 或者 SinglechildScrollview 或者 Container。
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(),
);
},
),
],
),
);
}
}
uj5u.com熱心網友回復:
首先感謝您的回答。我用 Column 和 SinglechildScrollview 嘗試過,但后來我得到另一個錯誤,即缺少 MediaQuery 小部件
媒體查詢錯誤
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/411961.html
標籤:
