我想在ListView中显示我的shopList的每个项目,但是我无法找出为什么它继续显示相同记录的原因。请帮助解决此问题。
这里有代码,从firebase数据库获取数据。
databaseReference.once().then((DataSnapshot snapshot) {
Map<dynamic, dynamic> getMap = snapshot.value;
getMap.forEach((k, v) {
Map<dynamic, dynamic> f = v;
shop.key = k;
shop.shopName = f["ShopName"];
shop.tel = f["ShopTel"];
shop.address = f["ShopAddress"];
shop.thumbnail = f["Thumbnail"];
debugPrint(k);
shopList.add(shop);
debugPrint(shopList[shopList.length-1].shopName);
});
});
DebugPrint结果:
这里是ListView的代码:
child: Flexible(
child: new ListView.builder(
itemCount: shopList.length,
itemBuilder: (context, index) {
return new Card(
color: Colors.red,
//elevation: 2.0,
child: new ListTile(
title: new Text("Name: ${shopList[index].key}"),
),
);
}),
),
模拟器的结果:
答案 0 :(得分:1)
尝试一下。
那就是我要做的
Shop.dart
class Shop {
String key;
String name;
String address;
String phone;
String thumbnail;
Shop(this.name,this.address,this.phone,this.thumbnail);
Shop.fromSnapshot(DataSnapshot snapshot)
: key = snapshot.key,
name = snapshot.value["name"],
address= snapshot.value["address"],
phone= snapshot.value["phone"],
thumbnail= snapshot.value["thumbnail"];
toJson() {
return {
"name": name,
"address": address,
"phone": phone,
"thumbnail": thumbnail,
};
}
}
main.dart
List<Shop> itemsShop = List();
Shop itemShop;
DatabaseReference itemRefShop;
@override
void initState() {
super.initState();
itemShop = Shop("", "", "", "");
final FirebaseDatabase database = FirebaseDatabase.instance;
itemRefShop = database.reference().child('Shop');
itemRefShop.onChildAdded.listen(_onEntryAddedShop);
itemRefShop.onChildChanged.listen(_onEntryChangedShop);
}
_onEntryAddedShop(Event event) {
setState(() {
itemsShop.add(Shop.fromSnapshot(event.snapshot));
});
}
_onEntryChangedShop(Event event) {
var old = itemsShop.singleWhere((entry) {
return entry.key == event.snapshot.key;
});
setState(() {
itemsShop[Shop.indexOf(old)] = Shop.fromSnapshot(event.snapshot);
});
}
@override
Widget build(BuildContext context) {
return new Container(
child: new Column(
children: <Widget>[
new Flexible(
child: new FirebaseAnimatedList(
query: itemRefShop,
itemBuilder:(_, DataSnapshot snapshot, Animation<double> animation, int index){
return new ListTile(
title: new Text(snapshot.value['name']),
subtitle: new Text(itemsShop[index].address),
);
}
),
]
),
);
}
}