【发布时间】:2025-11-25 12:00:02
【问题描述】:
我正在尝试使用 Future 从 firestore 数据库中获取单个字符串数据,然后在 FutureBuilder 中使用该数据。但是在快照数据中获得null 值。提供了下面的完整代码。告诉我哪里出错了。
我可以在fetchPost() 函数中打印数据。从firestore获取数据后,它进入FutureBuilder,
但快照数据为空-AsyncSnapshot<String>(ConnectionState.done, null, null)
import 'dart:async';
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
Future <String>fetchPost() async {
final DocumentReference documentReference = Firestore.instance.document("myData/dummy");
documentReference.get().then((datasnapshot){
if(datasnapshot.exists){
print("get data" +datasnapshot.data['url']); ///this printing data //in console
return datasnapshot.data['url'];
}
}).catchError((e){
print("Error");
print(e);
});
}
void main() => runApp(MyApp(post: fetchPost()));
class MyApp extends StatelessWidget {
final Future<String> post;
MyApp({Key key, this.post}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Fetch Data Example',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: Scaffold(
appBar: AppBar(
title: Text('Fetch Data Example'),
),
body: Center(
child: FutureBuilder<String>(
future: post,
builder: (BuildContext context, AsyncSnapshot<String> snapshot) {
print ("snapshot has data");
print (snapshot); // this printing 'AsyncSnapshot<String>(ConnectionState.done, null, null)'
print (snapshot.data);// this printing null
if (snapshot.hasData) {
return Text(snapshot.data);
} else if (snapshot.hasError) {
return Text("${snapshot.error}");
}
// By default, show a loading spinner
return CircularProgressIndicator();
},
),
),
),
);
}
}
【问题讨论】:
-
datasnapshot.data['url'] 在控制台中打印数据。我在 return 语句上方添加了一个 print 语句。这显示了控制台中的数据。@pskink