gpt4 book ai didi

dart - Flutter - 使用 firebase 集合填充列表

转载 作者:IT王子 更新时间:2023-10-29 07:12:49 26 4
gpt4 key购买 nike

我有一个消息列表,我想用一个 firebase 集合在 init 上填充这些消息。

import 'package:flutter/material.dart';
import 'package:my_first_flutter_app/chatmessage.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:logging/logging.dart';
final Logger log = new Logger('ChatScreen');

class ChatScreen extends StatefulWidget {
@override
State createState() => new ChatScreenState();
}

class ChatScreenState extends State<ChatScreen> {
final TextEditingController _chatController = new TextEditingController();
final List<ChatMessage> _messages = <ChatMessage>[];

@override
Widget build(BuildContext context) {

return new Column(
children: <Widget>[
new Flexible(
child: ListView.builder(
padding: new EdgeInsets.all(8.0),
reverse: true,
itemBuilder: (_, int index) => _messages[index],
itemCount: _messages.length,
),
),
new Divider(
height: 1.0,
),
new Container(decoration: new BoxDecoration(
color: Theme.of(context).cardColor,
),
child: _chatEnvironment(),)
],
);
}
}

我试着这样做:

@override
Widget build(BuildContext context) {
Firestore.instance
.collection('chats')
.document('ROOM_1')
.collection("messages")
.getDocuments()
.then((snap) {
return new Column(
....

但是我需要返回一个 Widget,而这次尝试返回一个 Future

我如何在聊天屏幕页面初始化时用来 self 的 firestore 集合的数据填充 _messages 数组?

最佳答案

如果您只需要在 ListView 中显示来自 firestore 集合的所有消息,那么您可能会喜欢 StreamBuilder 小部件。你可以这样做:

return new Column(
children: <Widget>[
new Flexible(
child: StreamBuilder(
stream: Firestore.instance.collection('chats').document('ROOM_1').collection('messages').snapshots(),
builder: (context, snapshot){
if (!snapshot.hasData){
return Container(
child: Center(
child: Text("No data")
)
);
}

return ListView.builder(
padding: EdgeInsets.all(8.0),
reverse: true,
itemCount: snapshot.data.documents.length,
itemBuilder: (_, int index) {
return ChatMessage(text: snapshot.data.documents[index]["messageField"]); //I just assumed that your ChatMessage class takes a parameter message text
}
);
}
)

),
new Divider(
height: 1.0,
),

...

请注意,在此示例中,我没有使用 _messages 变量。

关于dart - Flutter - 使用 firebase 集合填充列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53977191/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com