Flutter -------- 解析JSON数据

Posted zhangqie

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Flutter -------- 解析JSON数据相关的知识,希望对你有一定的参考价值。

SON序列化方法:

手动序列化和反序列化
通过代码生成自动序列化和反序列化

手动JSON序列化是指使使用dart:convert中内置的JSON解码器。它将原始JSON字符串传递给JSON.decode() 方法,然后在返回的Map<String, dynamic>中查找所需的值。 它没有外部依赖或其它的设置,对于小项目很方便。

当您的项目变大时,手动编写序列化逻辑可能变得难以管理且容易出错。如果您在访问未提供的JSON字段时输入了一个错误的字段,则您的代码将会在运行时会引发错误。


一个简单的案列

接口请求的JSON数据

接口链接:https://jsonplaceholder.typicode.com/posts/1


  "userId": 1,
  "id": 1,
  "title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
  "body": "quia et suscipit\\nsuscipit recusandae consequuntur expedita et cum\\nreprehenderit molestiae ut ut quas totam\\nnostrum rerum est autem sunt rem eveniet architecto"

 

 final responseJson = json.decode(response.body);

 Map<String, dynamic> newTitle = responseJson ;

这种就是很简单的解析了

取值和Java Map一样了

print(newTitle[‘title‘]);//打印title的值

 

另一种 实体类解析了,模型类中序列化JSON类

//类的解析方式
 final responseJson = json.decode(response.body);
    print(responseJson.toString());
   
    Post postBean = Post.fromJson(responseJson);

 


简单的数据写fromJson还好,但复杂的手写fromJson,toJson不太友好。

如下图的列表数据,多层且分页

技术图片


我们可以使用 代码生成库序列化json

json_serializable package包

它是一个自动化的源代码生成器,可以为我们生成JSON序列化模板

依赖

 

dependencies:
  json_annotation: ^2.0.0


dev_dependencies:
  build_runner: ^1.0.0
  json_serializable: ^2.0.0

 

但这种我也不用,个人觉得有点麻烦,还是要写实体类代码


给大家推荐个网站,复制JSON数据进去直接生成,Dart的实体类 和androidGsonFormat一样

 

效果图:(上图接口请求的数据生成Dart实体)

 技术图片

 


网址:https://javiercbk.github.io/json_to_dart/

 

以上是关于Flutter -------- 解析JSON数据的主要内容,如果未能解决你的问题,请参考以下文章

将 Json 数据解析为现有的 Flutter 小部件

flutter json数据解析

Flutter -------- 解析JSON数据

使用flutter和php创建用户登录时解析json数据时出错

在 Flutter 中解析 JSON 时 Json.decode 挂起

如何在 Flutter 中解析这个 JSON 数组?