- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在使用 Flutter 设置使用电子邮件和密码注册时遇到问题。我让它登录新用户并保存他们的 Firebase 身份验证信息,但它不会将任何配置文件数据保存到 Firebase 存储部分。我不确定我在这里做错了什么,我不明白为什么 id 为空。一些帮助和指导将不胜感激!
这是我得到的错误
Unhandled Exception: NoSuchMethodError: The getter 'id' was called on null.
Receiver: null
Tried calling: id
这是来自 user.dart
import 'package:cloud_firestore/cloud_firestore.dart';
class User {
final String id;
final String profileName;
final String username;
final String photoUrl;
final String url;
final String email;
final String bio;
final String createdAt;
User({
this.id,
this.profileName,
this.username,
this.photoUrl,
this.url,
this.email,
this.bio,
this.createdAt,
});
factory User.fromDocument(DocumentSnapshot doc) {
return User(
id: doc.documentID,
email: doc['email'],
username: doc['username'],
photoUrl: doc['photoUrl'],
url: doc['url'],
profileName: doc['profileName'],
bio: doc['bio'],
createdAt: doc['createdAt'],
);
}
}
这是来自 Signup.dart
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:buddiesgram/models/user.dart';
import 'package:buddiesgram/pages/HomePage.dart';
import 'package:shared_preferences/shared_preferences.dart';
class SignupPage extends StatefulWidget {
static final String id = 'signup_page';
final DateTime timestamp = DateTime.now();
User currentUser;
@override
_SignupPageState createState() => _SignupPageState();
}
class _SignupPageState extends State<SignupPage> {
final FirebaseAuth auth = FirebaseAuth.instance;
final _formKey = GlobalKey<FormState>();
String username, email, password;
SharedPreferences preferences;
checkIfSignedIn() async {
auth.onAuthStateChanged.listen((user) {
if (user != null) {
Navigator.push(context, MaterialPageRoute(builder: (context) => HomePage()));
}
});
@override
void initState() {
super.initState();
this.checkIfSignedIn();
}
}
saveUserInfoToFireStore() async {
preferences = await SharedPreferences.getInstance();
DocumentSnapshot documentSnapshot = await usersReference.document(currentUser.id).get();
if(!documentSnapshot.exists) {
usersReference.document(currentUser.id).setData({
"id": currentUser.id,
"profileName": currentUser.profileName,
"username": currentUser.username,
"photoUrl": currentUser.photoUrl,
"email": currentUser.email,
"bio": "",
"timestamp": timestamp,
"talkingTo": null,
});
//Write data to local
//currentUser = currentUser as User;
//await preferences.setString("id", currentUser.id);
//await preferences.setString("profileName", currentUser.profileName);
//await preferences.setString("photoUrl", currentUser.photoUrl);
await followersReference.document(currentUser.id).collection("userFollowers").document(currentUser.id).setData({});
documentSnapshot = await usersReference.document(currentUser.id).get();
}
currentUser = User.fromDocument(documentSnapshot);
}
signUp() async {
if(_formKey.currentState.validate()) {
_formKey.currentState.save();
try{
AuthResult authResult = await auth.createUserWithEmailAndPassword(email: email, password: password);
FirebaseUser signedInUser = authResult.user;
if(signedInUser != null) {
saveUserInfoToFireStore();
}
Navigator.push(context, MaterialPageRoute(builder: (context) => HomePage()));
}
catch(e) {
print(e);
}
}
}
这是来自 Timeline.dart
retrieveTimeLine() async {
QuerySnapshot querySnapshot = await timelineReference.document(currentUser.id)
.collection("timelinePosts").orderBy("timestamp", descending: true).getDocuments();
List<Post> allPosts = querySnapshot.documents.map((document) => Post.fromDocument(document)).toList();
setState(() {
this.posts = allPosts;
});
}
retrieveFollowings() async {
QuerySnapshot querySnapshot = await followingReference.document(currentUser.id)
.collection("userFollowing").getDocuments();
setState(() {
followingsList = querySnapshot.documents.map((document) => document.documentID).toList();
});
}
如果我遗漏了什么,请告诉我,这可能会有所帮助。
最佳答案
currentUser
为空,因为您没有初始化该类。例如:
saveUserInfoToFireStore() async {
currentUser = User(); //initialize
preferences = await SharedPreferences.getInstance();
DocumentSnapshot documentSnapshot = await usersReference.document(currentUser.id).get();
当然上面的代码还是不行,因为
id
等于空。如果数据库中的文档 id 等于用户 uid,则执行以下操作:
User loggedInUser;
saveUserInfoToFireStore() async {
var user = FirebaseAuth.instance.currentUser();
loggedInUser = User(id : user.uid);
preferences = await SharedPreferences.getInstance();
DocumentSnapshot documentSnapshot = await usersReference.document(loggedInUser.id).get();
所以在这里你得到了
uid
来自 Firebase 身份验证的用户,然后由于您使用可选的命名参数,您可以初始化
User
与
id
一起上课属性并在
document()
中使用它方法。
关于Flutter:未处理的异常:NoSuchMethodError:在 null 上调用了 getter 'id'。接收者:空尝试调用:id,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62895099/
如果您有一个具有一些普通 get/set 属性的类,是否有任何理由在类方法中使用 getter,或者您应该只使用私有(private)成员变量?我认为关于setter(验证逻辑?)可能会有更多争论,但
我是 Android 编程的新手(~ 2 个月)有必要为几十个不同的变量设置 getter 吗? 例如—— //Yes I realise that this isn't 'dozens' publi
我是VUEX新手,在学习VUEX的同时搭建了一个测试应用。我已将我的 VUEX 存储拆分为多个模块,每个模块都有自己的 getter.js 文件。 Getters、 Action 、突变被导入到每个模
我有一项服务正在加载我想在多个组件之间共享的基本系统信息。 如果我在 getter 中创建一个 getter 方法 this 如果我不在服务中使用双箭头,则 getter 中的 this 成为组件的
tl;博士 如何从参数化的 getter 访问其他 getter? 通常可以使用this.myGetter ;但是参数化的 getter 被实现为箭头函数,其中 this未定义。 在 Pinia 中处
我第一次尝试做一些 OOP,这不是简单的练习,而是用 java 编写一个程序来存储有关人员的信息(如通讯录)。下面是我正在开发的名为 Person 的类的片段。 Person 将在将来的某个时间被其他
我在某处看到类似下面的内容,想知道它是什么意思。我知道他们是getter和setter,但是想知道为什么字符串Type是这样定义的。谢谢你帮助我。 public string Type { get;
Public class Example { private int number; public Example(int number){ this.number =
getter 应该只返回对象吗: public MyObject getMyObject() { return myObject; } 或者它应该复制它返回的对象并返回该副本? public
我目前正在处理大量数据输入,包括很多值,我希望在 getter 中接收这些值以供以后使用。 在编写了一些方法之后,我想知道仅使用一个 get 方法是否是一个更好的主意,并使用一个包含所有可能值的枚举类
我正在使用新的 Class Public Field Declarations可用 Chrome 72我遇到了这种真正奇怪的行为: class Extended { property = 5; }
我有一个这样的表达式 setter/getter : var expression = () => SomeInstance.Nr; 它被传递到一个方法中: public void AddExpres
我的一个类(class)中有以下 getter: get password(){ if(this._public) return null; var text = ""
我已经设法测试了与其他代码隔离的 Vuex getter。当 getter 依赖于其他 getter 时,我现在面临一些问题,请参见以下示例: getters.js export const gett
有时我的任务是查找 getter 返回的值中的某些嵌套 getter 是否具有某些属性。经典的 C++ 会是这样的: for (const auto& label: labels) for (co
我有一个像这样的基类“Parent”: using System; using System.Collections.Generic; using System.Text; namespace Con
我一直在努力了解 getter 和 setter,但没有深入了解。我读过 JavaScript Getters and Setters和 Defining Getters and Setters只是没
考虑一个简单的 Vue 博客: 我使用 Vuex 作为我的数据存储,我需要设置两个 getters :一个 getPost getter,用于通过 ID 检索 post,以及一个 listFeatur
我有一个 VueX 商店,有两个模块,user.js 和merchant.js,顶层是index.js。 user.js 中的 getter 是: 重构 const getters = { s
我正在尝试向 jsp 添加一个复选框以在进入站点之前接受条款和条件。尽管我有一个 getter 方法并且没有看到任何拼写错误,但我一直收到关于没有 getter 方法的相同错误。我不明白我错过了什么。
我是一名优秀的程序员,十分优秀!