max*_*max 3 database dart flutter flutter-dependencies
我即将在 Flutter 中使用数据库“Sembast”。具有 string 和 int 等数据类型的简单对象可以正常工作。但是,使用列表时会出现问题。
我创建了一个示例并针对以下教程进行了自我介绍:https : //resocoder.com/2019/04/06/flutter-nosql-database-sembast-tutorial-w-bloc/ 在我的示例中,有水果和树叶作为对象。一个水果包含一个叶子列表。
class Fruit {
final String id;
final String name;
final bool isSweet;
final List<Leaves> leaves;
...
}
class Leaves {
final String id;
final String name;
...
}
//Create a sample object
var leaveOne = Leaves(id: "1", name: "leaveOne");
var leaveTwo = Leaves(id: "2", name: "leaveTwo");
var leaveThree = Leaves(id: "3", name: "leaveThree");
var leavesList = List<Leaves>();
leavesList.add(leaveOne);
leavesList.add(leaveTwo);
leavesList.add(leaveThree);
var fruit = Fruit(id: "1", name: "Apple", isSweet: true, leaves: leavesList);
_fruitDao.insert(fruit);
// The fruitDao.insert makes following
Future insert(Fruit fruit) async {
await _fruitStore.add(await _db, fruit.toJson());
}
Run Code Online (Sandbox Code Playgroud)
JSON 看起来像这样:{id: 1, name: Apple, isSweet: true, Leaves: [Instance of 'Leaves', Instance of 'Leaves', Instance of 'Leaves']}
错误如下:[ERROR:flutter/lib/ui/ui_dart_state.cc(148)] 未处理的异常:无效的参数:值实例的“叶子”不受支持的类型叶子
正如所指出的,Instance of 'Leaves'不是有效类型,因此每个类型也Leave必须进行转换。很难在没有看到你的情况下猜测你在做什么,toJson()但这样的事情应该可以工作(可以在很大程度上进行优化):
class Fruit {
final String id;
final String name;
final bool isSweet;
final List<Leaves> leaves;
Fruit({this.id, this.name, this.isSweet, this.leaves});
Map<String, dynamic> toJson() => <String, dynamic>{
'id': id,
'name': name,
'isSweet': isSweet,
'leaves': leaves?.map((leave) => leave.toJson())?.toList(growable: false)
};
}
class Leaves {
final String id;
final String name;
Leaves({this.id, this.name});
Map<String, dynamic> toJson() => <String, dynamic>{'id': id, 'name': name};
}
Run Code Online (Sandbox Code Playgroud)
你的 json 应该是这样的:
{
"id": "1",
"name": "Apple",
"isSweet": true,
"leaves": [
{
"id": "1",
"name": "leaveOne"
},
{
"id": "2",
"name": "leaveTwo"
},
{
"id": "3",
"name": "leaveThree"
}
]
}
Run Code Online (Sandbox Code Playgroud)