淺談Flutter解析JSON三種方式

Dart實體類格式

class CategoryMo {
 String name;
 int count;

 CategoryMo({this.name, this.count});
 //將map轉成mo
 CategoryMo.fromJson(Map<String, dynamic> json) {
 name = json['name'];
 count = json['count'];
 }
 //將mo轉成map,可缺省
 Map<String, dynamic> toJson() {
 final Map<String, dynamic> data = new Map<String, dynamic>();
 data['name'] = this.name;
 data['count'] = this.count;
 return data;
 }
}

方案一:手寫實體類

person.json

{
 "name": "Jack",
 "age": 20
}

model轉換與使用

var personMap = {
 "name": "Jack",
 "age": 20
};
Person person = Person.fromJson(personMap);
print('name:${person.name}');
print('age:${person.age}');

方案二:生產力工具:json-to-dart插件自動生成實體類

方案三:生產力工具: json_ serializable使用技巧

安裝插件

dependencies:
...
 dio: ^3.0.10
 json_annotation: ^3.1.0


dev_dependencies:
...
 json_serializable: ^3.5.0
 build_runner: ^1.0.0

配置實體類

{
 "code": 0,
 "method": "GET",
 "requestPrams": "dd"
}
import 'package:json_annotation/json_annotation.dart';

// result.g.dart 將在我們運行生成命令後自動生成
part 'result.g.dart';

///這個標註是告訴生成器,這個類是需要生成Model類的
@JsonSerializable()
class Result {
 //定義構造方法
 Result(this.code, this.method, this.requestPrams);
 //定義字段
 int code;
 String method;
 String requestPrams;

 //固定格式,不同的類使用不同的mixin即可
 factory Result.fromJson(Map<String, dynamic> json) => _$ResultFromJson(json);
 //固定格式
 Map<String, dynamic> toJson() => _$ResultToJson(this);
}

因為實體類的生成代碼還不存在,所以上代碼會提示一-些錯誤是正常現象

執行build生成實體類

flutter packages pub run build_runner build

如何選擇

到此這篇關於淺談Flutter解析JSON三種方式的文章就介紹到這瞭,更多相關Flutter解析JSON內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!