我只是想找到一种方法来转换json响应(从REST API)到POJO(在android中使用),这样我就可以使用接收到的数据到我的应用程序中,因为使用Map不会足够,因为我接收的数据有点复杂,包含3个级别的数组(数组内部的数组)。
我正在使用Dio库进行API调用,我可以成功地进行API调用,并在控制台上打印数据,没有任何问题。有人可以帮助我实现这一点吗?
下面是我得到的答案。
{
"status": 200,
"message": "success",
"data": [
{
"menu": {
"megamenu_id": "55",
"language_id": "1",
"title": "Mobiles",
"description": "",
"submenu": [
{
"0": {
"info": {
"megamenu_id": "67",
"language_id": "1",
"title": "Mobile Phones",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "68",
"language_id": "1",
"title": "Android Phones",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "69",
"language_id": "1",
"title": "Smart Phones",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "70",
"language_id": "1",
"title": "Windows Phones",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "72",
"language_id": "1",
"title": "Basic Phones",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "73",
"language_id": "1",
"title": "Latest Mobiles",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "74",
"language_id": "1",
"title": "Upcoming Mobiles",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "75",
"language_id": "1",
"title": "Brands",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "76",
"language_id": "1",
"title": "Samsung",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "77",
"language_id": "1",
"title": "Apple",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "78",
"language_id": "1",
"title": "Redmi",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "79",
"language_id": "1",
"title": "Nokia",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "81",
"language_id": "1",
"title": "Sony",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "82",
"language_id": "1",
"title": "Micromax",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "83",
"language_id": "1",
"title": "HTC",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "84",
"language_id": "1",
"title": "Motorola",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "85",
"language_id": "1",
"title": "Oppo",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "86",
"language_id": "1",
"title": "Vivo",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "87",
"language_id": "1",
"title": "Honor",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "88",
"language_id": "1",
"title": "Oneplus",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "94",
"language_id": "1",
"title": "Mobile Accessories",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "95",
"language_id": "1",
"title": "Bluetooth Headsets",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "96",
"language_id": "1",
"title": "Mobile Chargers",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "97",
"language_id": "1",
"title": "Mobiles Cases & Covers",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "98",
"language_id": "1",
"title": "Screen Protector",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "99",
"language_id": "1",
"title": "Mobile Batteries",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "100",
"language_id": "1",
"title": "Headphones & Headsets",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "101",
"language_id": "1",
"title": "Memory Cards",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "102",
"language_id": "1",
"title": "Power Banks",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "103",
"language_id": "1",
"title": "Stylus",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "104",
"language_id": "1",
"title": "Mobile Docks",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "107",
"language_id": "1",
"title": "Features",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "108",
"language_id": "1",
"title": "Dual Sim Phones",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "111",
"language_id": "1",
"title": "4GB Ram Mobiles",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "112",
"language_id": "1",
"title": "Rear Camera [13 MP]",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "113",
"language_id": "1",
"title": "Screen Size [4.5 - 5.2 Inch]",
"description": ""
}
}
]
}
]
}
},
{
"menu": {
"megamenu_id": "168",
"language_id": "1",
"title": "Fashion",
"description": "",
"submenu": [
{
"0": {
"info": {
"megamenu_id": "169",
"language_id": "1",
"title": "Clothing",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "170",
"language_id": "1",
"title": "T-Shirts",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "171",
"language_id": "1",
"title": "Shirts",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "178",
"language_id": "1",
"title": "Womens Clothing",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "187",
"language_id": "1",
"title": "Night Wear",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "188",
"language_id": "1",
"title": "Tunics",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "189",
"language_id": "1",
"title": "Kurtis",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "190",
"language_id": "1",
"title": "Sarees",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "191",
"language_id": "1",
"title": "Lehengas",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "192",
"language_id": "1",
"title": "Swimming Suit",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "193",
"language_id": "1",
"title": "Men's Footwear",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "194",
"language_id": "1",
"title": "Shoes",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "195",
"language_id": "1",
"title": "Sneakers",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "196",
"language_id": "1",
"title": "Sandals & Floaters",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "197",
"language_id": "1",
"title": "Slippers & Flip Flops",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "198",
"language_id": "1",
"title": "Loafers",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "199",
"language_id": "1",
"title": "Boots",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "200",
"language_id": "1",
"title": "Shoe Care",
"description": ""
}
}
]
},
{
"0": {
"info": {
"megamenu_id": "201",
"language_id": "1",
"title": "Women's Jewellery",
"description": ""
}
},
"subsubmenu": [
{
"infosub": {
"megamenu_id": "202",
"language_id": "1",
"title": "Earrings",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "203",
"language_id": "1",
"title": "Bangles",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "204",
"language_id": "1",
"title": "Bracelets",
"description": ""
}
},
{
"infosub": {
"megamenu_id": "205",
"language_id": "1",
"title": "Rings",
"description": ""
}
}
]
}
]
}
},
{
"menu": {
"megamenu_id": "220",
"language_id": "1",
"title": "Care",
"description": ""
}
},
{
"menu": {
"megamenu_id": "221",
"language_id": "1",
"title": "Offers",
"description": ""
}
},
{
"menu": {
"megamenu_id": "222",
"language_id": "1",
"title": "News",
"description": ""
}
}
]
}
字符串
6条答案
按热度按时间mec1mxoz1#
Android Studio插件:https://plugins.jetbrains.com/plugin/12562-jsontodart-json-to-dart-
在线:https://app.quicktype.io/?l=dart
手动解析:https://medium.com/flutter-community/parsing-complex-json-in-flutter-747c46655f51
从JSON生成Dart类
将JSON转换为Dart类
从JSON或JSON-Schema生成Dart类。
x1c 0d1x的数据
h7appiyu2#
json_serializable没有很好的文档记录,但是它确实可以做你想要的事情,比built_value更容易使用,需要的样板文件更少,特别是在数组方面。
字符串
它还支持枚举序列化。
若要产生序列化程式码,请执行:
型
ffdz8vbo3#
所以,在尝试了一些json_serializable库之后,我想出了自己的解决方案,它根本不需要任何外部库,并且工作起来很有魅力。这样我就不必编写更少的样板代码,我认为这是一种干净的方法。
下面是如何制作模型
字符串
然后这样叫
型
就是这样!
wkyowqbh4#
这可以使用built_value完成。详细文档可在此链接中找到。
您只需编写一些样板代码并运行此命令
flutter packages pub run build_runner build
。下面是一个类似POJO的示例类。
字符串
下面是Serializer类:
型
下面是从JSON到Object转换的代码。
型
希望这对你有帮助。
m3eecexj5#
请查看this post以获得最佳选项,以实现您的目标
odopli946#
使用Android Studio的用户可以尝试以下选项
Settings -> Plugins -> FlutterJsonBeanFactory
(安装此插件)这个怎么用?
右键单击
lib -> new -> JsonToDartBeanAction
输入
class
名称并粘贴json
数据。就这样。请注意 * 当json数据需要传递到body进行http请求时,结果dart文件中返回的json方法中的jsonToJson方法不起作用,而是使用jsonEncode(object)
请参阅下面的图片以供参考
的数据
的