我是 Flutter 的新手。我正在尝试开发一个应用程序。
我想显示 Firebase 数据库中的人员列表。但是,我收到以下错误。
错误:
<块引用>方法'[]'不能无条件调用,因为接收者 可以为“空”。尝试使呼叫有条件(使用 '?.')或添加 对目标的空检查 ('!').
科德拉姆:
`import 'package:calendar/page/mainPage.dart';
import 'package:flutter/material.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
class Staff extends StatefulWidget {
@override
_StaffState createState() => _StaffState();
}
class _StaffState extends State<Staff> {
final _firestore = FirebaseFirestore.instance;
@override
Widget build(BuildContext context) {
// ignore: unused_local_variable
CollectionReference staffRef = _firestore.collection('staff');
return Scaffold(
appBar: AppBar(
title: Text("Personel Listesi"),
backgroundColor: Colors.redAccent[400],
actions: <Widget>[
IconButton(
icon: Icon(Icons.home),
onPressed: () {
Navigator.pushAndRemoveUntil(
context,
MaterialPageRoute(builder: (_) => MainPage()),
(route) => true);
},
),
],
),
body: Container(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Center(
child: Column(
children: [
StreamBuilder<QuerySnapshot>(
stream: staffRef.snapshots(),
builder: (BuildContext context, AsyncSnapshot asyncSnapshot) {
if (asyncSnapshot.hasError) {
return Center(
child: Text(
"Bir hata oluştu, lütfen tekrar deneyiniz."));
} else {
if (asyncSnapshot.hasData) {
List<DocumentSnapshot> listStaff =
asyncSnapshot.data.docs;
return Flexible(
child: ListView.builder(
itemBuilder: (context, index) {
return Card(
elevation: 20,
color: Colors.greenAccent[200],
child: ListTile(
trailing: IconButton(
icon: Icon(Icons.delete),
onPressed: () async {
await listStaff[index]
.reference
.delete();
},
),
title: Text(
'${listStaff[index].data['nameSurname']}',
style: TextStyle(fontSize: 20),
),
subtitle: Column(
children: [
Row(
mainAxisAlignment:
MainAxisAlignment.start,
children: [
Text(
'${listStaff[index].data['tip']}',
style: TextStyle(fontSize: 14),
),
],
),
Row(
mainAxisAlignment:
MainAxisAlignment.start,
children: [
Text(
'${listStaff[index].data['mail']}',
style: TextStyle(fontSize: 14),
),
],
),
Row(
mainAxisAlignment:
MainAxisAlignment.start,
children: [
Text(
'${listStaff[index].data['phone']}',
style: TextStyle(fontSize: 14),
),
],
),
],
),
),
);
},
itemCount: listStaff.length),
);
} else {
return Center(
child: CircularProgressIndicator(),
);
}
}
},
),
],
),
),
),
),
);
}
}
`
答案 0 :(得分:0)
这是一个典型的空安全相关错误。我没有尝试代码,我猜可能将 asyncSnapshot.data.docs
分配给 listStaff
可能会返回 null,但是您声明的类型 List<DocumentSnapshot>
不允许那。如果您 100% 确定此分配不会返回空值,则可以添加“!”确保编译器,它将是 List,所以它会让你使用方法。虽然如果您希望此列表为空,您可以简单地添加 '?'来显示它,而不是使用 '?.'使用方法。它的工作原理是:检查对象是否为空,如果不是,则在此方法上执行方法。
答案 1 :(得分:0)
在新的flutter更新中,我们不需要添加.data()
下面是我的代码
title: Text(
**'${listStaff[index].data['nameSurname']}',**
style: TextStyle(fontSize: 20),
),
像这样改变它修复了错误。
title: Text(
**'${listPersonel[index]['nameSurname']}'**,
style: TextStyle(fontSize: 20),
),
答案 2 :(得分:0)
如果您访问可空 List
或 Map
上的元素,则会收到此错误。让我们了解一下 List
,您可以为您的 Map
应用相同的解决方案。
例如:
List<int>? someList;
void main() {
int a = someList[0]; // Error
}
使用局部变量:
var list = someList;
if (list != null) {
int a = list[0]; // No error
}
使用?
和??
:
int a = someList?[0] ?? -1; // -1 is the default value if List was null
仅当您确定 !
不是 List
时才使用 null
bang 运算符。
int a = someList![0];
FutureBuilder
/StreamBuilder
的人:您可以通过两种方式解决错误:
为您的 FutureBuilder
/StreamBuilder
指定类型
FutureBuilder<List<int>>( // <-- type 'List<int>' is specified.
future: _listOfInt(),
builder: (_, snapshot) {
if (snapshot.hasData) {
List<int> myList = snapshot.data!; // <-- Your data
}
return Container();
},
)
使用 as
将 Object
向下转换为您的类型,例如 List
或 Map
。
FutureBuilder(
future: _listOfInt(),
builder: (_, snapshot) {
if (snapshot.hasData) {
var myList = snapshot.data! as List<int>; // <-- Your data using 'as'
}
return Container();
},
)