0

我正在尝试使用 StreamProvider 和 StreamBuilder 将数据从 firestore 提取到我的应用程序中,代码如下。我收到错误“未定义流用户和“用户列表”以及“testuser”不是类型。这是我的 firestore 数据库firestore 设置的图片] 1

有谁知道我该如何解决这个问题,以便它从firestore中提取数据并在添加新用户时动态更新?

主要飞镖:

class _MyHomePageState extends State<MyHomePage> {
  final auth = FirebaseAuth.instance;
  final db = DatabaseService();

  @override
  Widget build(BuildContext context) {

    var user = Provider.of<FirebaseUser>(context);
    bool loggedIn = user != null;

    final _width = MediaQuery.of(context).size.width;
    final _height = MediaQuery.of(context).size.height;

    StreamProvider<List<User>>.value(
      value: db.streamUsers(user),
      child: UsersList(),
    ),

    StreamBuilder<TestUser>(
      stream: db.streamTestUser(user.uid),
        builder: (context, snapshot) {
        var user = snapshot.data;

        if (user != null) {
            return Stack(...

我也有我的 db.dart 文件:

class DatabaseService {
  final Firestore _db = Firestore.instance;

  Future<User> getUser(String id) async {
    var snap = await _db.collection('users').document(id).get();

    return User.fromMap(snap.data);
  }

    Stream<User> streamTestUser(String id) {
      return _db
          .collection('users')
          .document(id)
          .snapshots()
          .map((snap) => User.fromMap(snap.data));
    }

}

最后是我的 user_model.dart 文件:

class User {

  final String name;
  final String photourl;
  final int totalquestions;

  User({this.name, this.photourl, this.totalquestions});

  factory User.fromMap(Map data) {
    return User(
      name: data['name'] ?? '',
      photourl: data['photourl'] ?? '',
      totalquestions: data['totalquestions'] ?? '',
    );
  }
}
4

1 回答 1

3

尝试使用BuilderinsideStreamProvider而不是StreamBuilder. 我正在使用这种方法。

class MyHomePage extends StatelessWidget {
@override
Widget build(BuildContext context) {
  var user = Provider.of<FirebaseUser>(context);

  return StreamProvider<User>.value(
    value: db.getUser(user?.uid),
    catchError: (_, __) => null,
    child: Builder(
      builder: (context) {
        ///Passing UserData Down the Builder
        var _userSnapshot = Provider.of<UserData>(context);

        ///Check UserData Availability
        if (_userSnapshot == null) {
          return Center(
            child: Text('User Empty'),
          );
        } else {
          return Scaffold(
            body: Column(
              children: <Widget>[
                Text(_userSnapshot?.name),
                Text(_userSnapshot?.photourl),
                Text(_userSnapshot?.totalquestions),
              ],
            ),
          );
        }
      },
    ),
  );
}
于 2019-11-30T04:16:15.927 回答