- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 flutter 应用程序中,当单击复选框以指示已完成的任务时,理想情况下,我需要将其反射(reflect)在 Firestore 数据库中。有一个名为“todo”的集合,每个文档都有以下字段:task_id、user_id、done、task,其中 task 是实际要完成的事情(字符串),done 是一个 bool 字段。因此,当单击复选框时,我的代码会使用参数任务名称调用函数 invertDone。这样做基本上是使用任务名称来查询集合以找到正确的文档并获取 docId。然后获取快照并且反转该文档的“完成”字段。
Future<void> invertDone(String task) async {
//get docid of task with task name..invert its bool field
todo.where('task', isEqualTo: task).get().then(
(QuerySnapshot snapshot) => {
snapshot.docs.forEach((f) {
todoid = f.reference.id;
print('todoid found is $todoid');
//new
FirebaseFirestore.instance
.runTransaction((transaction) async {
// Get the document
DocumentSnapshot snapshot = await transaction.get(todoid);
if (!snapshot.exists) {
throw Exception("User does not exist!");
}
temp = snapshot.data()['done'];
print('it was $temp');
temp = !temp;
print('now its $temp');
transaction.update(todoid, {'done': temp});
})
.then((value) => print("data updated"))
.catchError((error) => print("Failed to update : $error"));
//new done
}),
},
);
}
这个要更新的代码直接来自文档,显示的错误是
“String”类型不是“DocumentReference”类型的子类型 .
bool temp;
var todoid;
int number = 0;
final auth = FirebaseAuth.instance;
Stream collectionStream =
FirebaseFirestore.instance.collection('todo').snapshots();
CollectionReference main = FirebaseFirestore.instance.collection('maindb');
CollectionReference todo = FirebaseFirestore.instance.collection('todo');
final myController = TextEditingController();
class Todo extends StatefulWidget {
final String docid;
final bool isCaretaker;
Todo({this.docid, this.isCaretaker});
@override
_TodoState createState() => _TodoState();
static const String id = 'todoscreen';
}
Future<void> addTask(String task) async {
Map<String, dynamic> data = {
'task_id': number,
'user_id': docid,
'task': task,
'done': false
};
await todo.add(data);
number++;
}
Future<void> invertDone(String task) async {
//get docid of task with task name..invert its bool field
todo.where('task', isEqualTo: task).get().then(
(QuerySnapshot snapshot) => {
snapshot.docs.forEach((f) {
todoid = f.reference.id;
print('todoid found is $todoid');
//new
FirebaseFirestore.instance
.runTransaction((transaction) async {
// Get the document
DocumentSnapshot snapshot = await transaction.get(todoid);
if (!snapshot.exists) {
throw Exception("User does not exist!");
}
temp = snapshot.data()['done'];
print('it was $temp');
temp = !temp;
print('now its $temp');
transaction.update(todoid, {'done': temp});
// Return the new count
//return temp;
})
.then((value) => print("data updated"))
.catchError((error) => print("Failed to update : $error"));
//new done
}),
},
);
}
_openPopup(context) {
Alert(
context: context,
title: "Add Todo",
style: AlertStyle(titleStyle: Theme.of(context).textTheme.headline1),
content: Column(children: <Widget>[
TextField(
controller: myController,
decoration: InputDecoration(
icon: Icon(Icons.check),
labelText: 'Task',
labelStyle: Theme.of(context).textTheme.headline1,
),
),
]),
buttons: [
DialogButton(
color: Colors.transparent,
onPressed: () {
addTask(myController.text);
Navigator.pop(context);
myController.clear();
//print(myController.text);
},
child: Text(
"ADD TASK",
style: Theme.of(context).textTheme.headline1,
),
)
]).show();
}
class _TodoState extends State<Todo> {
@override
void dispose() {
// Clean up the controller when the widget is disposed.
myController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
backgroundColor: Color(0xFF602247),
toolbarHeight: 50.0,
centerTitle: true,
title: Text(
'VITALITY',
style: Theme.of(context).textTheme.headline3,
),
automaticallyImplyLeading: false,
actions: [
Visibility(
visible: isCaretaker,
child: IconButton(
icon: Icon(Icons.add, color: Colors.white, size: 30.0),
onPressed: () {
_openPopup(context);
})),
],
),
body: StreamBuilder(
stream: FirebaseFirestore.instance
.collection('todo')
.where('user_id', isEqualTo: docid)
.snapshots(),
builder: (context, snapshot) {
return Center(
child: ListView.builder(
itemCount: snapshot.data.docs.length,
itemBuilder: (context, index) {
DocumentSnapshot task = snapshot.data.docs[index];
bool _checked = task['done'];
return StatefulBuilder(
builder: (BuildContext context, StateSetter setState) {
return CheckboxListTile(
title: Text(task['task']),
value: _checked,
onChanged: isCaretaker
? (bool value) {
print('do u want to delete ');
}
: (bool value) {
print('initially checked is $_checked');
setState(() {
_checked = value;
print(_checked.toString());
});
invertDone(task['task']);
},
secondary: const Icon(Icons.hourglass_empty),
);
});
// return ListTile(title: Text(course['task']));
}),
);
},
)
// Center(
// child: Column(
// children: <Widget>[
// Text(widget.docid),
// Text(widget.isCaretaker.toString()),
// ],
// ),
// ),
,
bottomNavigationBar: bottomAppBar(id: widget.docid));
}
}
最佳答案
您似乎正在将文档 ID(它是 String
)分配给 todoid
这里
todoid = f.reference.id;
相反,您实际上需要分配一个
DocumentReference
到它。所以你需要改变这个。
todoid = f.reference;
并且理想情况下也相应地更改变量的名称。
关于 flutter 火炉 : updating a boolean field: type 'String' is not a subtype of type 'DocumentReference' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67567221/
我正在尝试从文本文件构建 boolean 值[][]。我正在读取每个字符,存储在 ArrayList 中(1 为真,0 为假)。我试过 ArrayList,但出现编译错误,意外元素。因此,我构建了一个
我想知道编程语言中的运算符优先级是否取决于实现,还是所有语言都遵循固定的规则。并且,如果可能的话,您可以先排序以下具有最高优先级的运算符吗:AND,OR,NOT,XOR。 最佳答案 我在Google上
这是同样的事情,对吗?还是有细微的差别?我只是想确保我没有误解任何事情。 最佳答案 通过简单地将 AND 替换为 OR 以及将 OR 替换为 AND 即可生成 boolean 对偶。补码本身不受影响,
我想这对于大多数优秀的程序员来说是微不足道的,但我已经习惯使用 true 进行编程。和 false 2、当我遇到0和1的时候,我永远记不住哪一个是真的,哪一个是假的。 有什么建议? 1好:I mean
我正在尝试将此 Java 示例转换为 Kotlin: Gson gson = new GsonBuilder() .registerTypeAdapter(Boolean.class,
下面的代码打印 true。 public static void main(String[] args) { Boolean test = false; test =
我在处理应该导致在 iReport 中显示或隐藏 strip 的表达式时遇到困难。 这些是我拥有的变量: Integer mainGroupInt = Integer.valueOf(5); Inte
以下编码错误可能是因为 Boolean equals(Object) 方法不需要 boolean/Boolean 参数: private void foo() { Boolean isSome
我想简化一个 boolean 表达式。 表达式是这样的 X1 xor (X2 || X3 && X4 || x5) 如何使用 boolean 代数规则简化此表达式。 而且我想将上面的 boolean
我正在使用一些工具,它可以确定特定事务是否成功的唯一方法是它是否通过了各种检查。但是,它的方式有限制,一次只能做一次检查,而且必须是顺序的。一切都必须从左到右计算。 例如, A || C && D 它
在大多数编程语言中,1和 0可以用来代替 True和 False .然而,根据我的经验,整数似乎总是更容易使用。 以下是我的意思的一些示例: if x is True: x = False else:
我有一个 boolean 方程,想简化它。帮忙解决一下。 bool needLoad = isA || (!isA && !isB); 之后我使用 if (needLoad){ if (
我认为这始终是正确的 x || (x && y) 相当于 x 如果是这样,那条法律叫什么?我什至不知道如何通过 Google 搜索该信息。 最佳答案 它被称为 Redundancy Law . A +
是否有任何现有的方法或功能模块可以有效地翻转 boolean 值? 如果我必须定义自己的实用方法,我想出了一个简单的实现,但我想知道这是否是最有效的方法: IF iv_bool = abap_true
我有这个表达式:X'YZ'+X'YZ+XY'Z'+XYZ'+XYZ('表示不是)我知道答案是 Y+XZ' 但我陷入了最后一部分。有人可以帮我吗? 这是我到目前为止得到的: X'YZ' + X'YZ +
openCL 支持 boolean 变量吗?我目前正在使用 JOCL (java) 编写我的 openCL 调用代码,但我没有看到任何有关 boolean 值的信息。 最佳答案 tl;dr:是的,但您
我认为这是对的 x || (x && y) 相当于 x 如果是这样,那条法律叫什么?我什至不确定我会如何使用 Google。 最佳答案 它叫做 Redundancy Law . A + A·B = A
我有一些功能,例如 (A and ( B or c)) or (D and E and (F or H or R or P ))) 我想将该函数转换为仅包含 and 操作的函数(当然如果可能的话)我发
我参加了编程面试,由 3 名面试官组成,每人 45 分钟。虽然前两位面试官给了我 2-3 个简短的编码问题(即反向链表、使用 rand(5) 实现 rand(7) 等),但第三位面试官使用了整个时间段
如果我只想检查某事是否不可能(即,我不会使用类似 if(possible) 的东西),我应该将 boolean 值命名为 notPossible并使用 if(notPossible)或者我应该命名它p
我是一名优秀的程序员,十分优秀!