无法将 JSON 值提取到 flutter 字段
Not Able to Fetch JSON values to field in flutter
我能够成功获取 JSON 数据,但无法获取 JSON 数据的字段并在 flutter 中构建列表。
这是我用来获取字段数据的代码
OrderModel.fromJson(Map<String, dynamic> json) {
error = json['error'];
if (json['content'] != null) {
content = new List<OrderContent>();
json['content'].forEach((v) {
content.add(new OrderContent.fromJson(v));
});
}
}
json['content']
是 Map<String, dynamic>
。
在.forEach((v)
中我应该写什么来获取数据?我是这个flutter和JSON学习的新手,我想我只是在这一点上错了
我正在处理的 JSON 数据结构如下
{
"error": "false",
"content": {
"16": [
[
{
"sod_pk": "31688",
"soh_fk": "23660",
"sqd_fk": "33294",
"order_header": {
"soh_pk": "23660",
"order_no": "16",
}
}
],
[
{
"sod_pk": "31689",
"soh_fk": "23660",
"sqd_fk": "33293",
"order_header": {
"soh_pk": "23660",
"order_no": "16",
}
}
]
],
"18": [
[
{
"sod_pk": "31744",
"soh_fk": "23702",
"sqd_fk": "33354",
"order_header": {
"soh_pk": "23702",
"order_no": "18",
}
}
],
[
{
"sod_pk": "31745",
"soh_fk": "23702",
"sqd_fk": "33356",
"order_header": {
"soh_pk": "23702",
"order_no": "18",
}
}
],
]
}
}
上面的JSON数据结构在每一个item details中都有order no嵌套,必须在所有的order number里面取出来,然后是订单各自的数据。
您可以复制粘贴 运行 下面的完整代码
第一步:可以用payloadFromJson
解析,content
字段为Map<String, List<List<OrderContent>>>
,完整代码见下方
第 2 步:显示 FutureBuilder
和 ListView.separated
工作演示
完整代码
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:convert';
Payload payloadFromJson(String str) => Payload.fromJson(json.decode(str));
String payloadToJson(Payload data) => json.encode(data.toJson());
class Payload {
Payload({
this.error,
this.content,
});
String error;
Map<String, List<List<OrderContent>>> content;
factory Payload.fromJson(Map<String, dynamic> json) => Payload(
error: json["error"],
content: Map.from(json["content"]).map((k, v) =>
MapEntry<String, List<List<OrderContent>>>(
k,
List<List<OrderContent>>.from(v.map((x) =>
List<OrderContent>.from(
x.map((x) => OrderContent.fromJson(x))))))),
);
Map<String, dynamic> toJson() => {
"error": error,
"content": Map.from(content).map((k, v) => MapEntry<String, dynamic>(
k,
List<dynamic>.from(
v.map((x) => List<dynamic>.from(x.map((x) => x.toJson())))))),
};
}
class OrderContent {
OrderContent({
this.sodPk,
this.sohFk,
this.sqdFk,
this.orderHeader,
});
String sodPk;
String sohFk;
String sqdFk;
OrderHeader orderHeader;
factory OrderContent.fromJson(Map<String, dynamic> json) => OrderContent(
sodPk: json["sod_pk"],
sohFk: json["soh_fk"],
sqdFk: json["sqd_fk"],
orderHeader: OrderHeader.fromJson(json["order_header"]),
);
Map<String, dynamic> toJson() => {
"sod_pk": sodPk,
"soh_fk": sohFk,
"sqd_fk": sqdFk,
"order_header": orderHeader.toJson(),
};
}
class OrderHeader {
OrderHeader({
this.sohPk,
this.orderNo,
});
String sohPk;
String orderNo;
factory OrderHeader.fromJson(Map<String, dynamic> json) => OrderHeader(
sohPk: json["soh_pk"],
orderNo: json["order_no"],
);
Map<String, dynamic> toJson() => {
"soh_pk": sohPk,
"order_no": orderNo,
};
}
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
Future<Payload> _future;
Future<Payload> getData() async {
String jsonString = '''
{
"error": "false",
"content": {
"16": [
[
{
"sod_pk": "31688",
"soh_fk": "23660",
"sqd_fk": "33294",
"order_header": {
"soh_pk": "23660",
"order_no": "16"
}
}
],
[
{
"sod_pk": "31689",
"soh_fk": "23660",
"sqd_fk": "33293",
"order_header": {
"soh_pk": "23660",
"order_no": "16"
}
}
]
],
"18": [
[
{
"sod_pk": "31744",
"soh_fk": "23702",
"sqd_fk": "33354",
"order_header": {
"soh_pk": "23702",
"order_no": "18"
}
}
],
[
{
"sod_pk": "31745",
"soh_fk": "23702",
"sqd_fk": "33356",
"order_header": {
"soh_pk": "23702",
"order_no": "18"
}
}
]
]
}
}
''';
http.Response response = http.Response(jsonString, 200);
if (response.statusCode == 200) {
return payloadFromJson(response.body);
}
}
@override
void initState() {
_future = getData();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: FutureBuilder(
future: _future,
builder: (context, AsyncSnapshot<Payload> snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.none:
return Text('none');
case ConnectionState.waiting:
return Center(child: CircularProgressIndicator());
case ConnectionState.active:
return Text('');
case ConnectionState.done:
if (snapshot.hasError) {
return Text(
'${snapshot.error}',
style: TextStyle(color: Colors.red),
);
} else {
return ListView.separated(
separatorBuilder: (BuildContext context, int index) {
return SizedBox(
height: 30,
);
},
itemCount: snapshot.data.content.keys.length,
itemBuilder: (context, index) {
String key =
snapshot.data.content.keys.elementAt(index);
return Column(
children: [
Text(key),
ListView.separated(
separatorBuilder:
(BuildContext context, int index) {
return SizedBox(
height: 10,
);
},
shrinkWrap: true,
itemCount: snapshot.data.content[key].length,
itemBuilder: (context, index) {
return Column(
children: [
Text(snapshot
.data.content[key][index][0].sodPk),
Text(snapshot
.data.content[key][index][0].sqdFk),
Text(snapshot.data.content[key][index][0]
.orderHeader.sohPk),
],
);
},
)
],
);
});
}
}
}));
}
}
你的json没有优化好难处理。
首先,你看到你的 json['content'] 不是一个列表,所以你不能使用 foreach 来获取数据。它是一个对象(地图){...}。但是扑动不确切地知道它是什么的地图,所以你必须投射它。其次,要获得 sod_pk
例如,您必须通过 2 个列表。这是不必要的。这是代码
final content = (data['content'] as Map<String, dynamic>);
final sod_pk = content['16'].first.first['sod_pk'];
print(sod_pk);
我能够成功获取 JSON 数据,但无法获取 JSON 数据的字段并在 flutter 中构建列表。
这是我用来获取字段数据的代码
OrderModel.fromJson(Map<String, dynamic> json) {
error = json['error'];
if (json['content'] != null) {
content = new List<OrderContent>();
json['content'].forEach((v) {
content.add(new OrderContent.fromJson(v));
});
}
}
json['content']
是 Map<String, dynamic>
。
在.forEach((v)
中我应该写什么来获取数据?我是这个flutter和JSON学习的新手,我想我只是在这一点上错了
我正在处理的 JSON 数据结构如下
{
"error": "false",
"content": {
"16": [
[
{
"sod_pk": "31688",
"soh_fk": "23660",
"sqd_fk": "33294",
"order_header": {
"soh_pk": "23660",
"order_no": "16",
}
}
],
[
{
"sod_pk": "31689",
"soh_fk": "23660",
"sqd_fk": "33293",
"order_header": {
"soh_pk": "23660",
"order_no": "16",
}
}
]
],
"18": [
[
{
"sod_pk": "31744",
"soh_fk": "23702",
"sqd_fk": "33354",
"order_header": {
"soh_pk": "23702",
"order_no": "18",
}
}
],
[
{
"sod_pk": "31745",
"soh_fk": "23702",
"sqd_fk": "33356",
"order_header": {
"soh_pk": "23702",
"order_no": "18",
}
}
],
]
}
}
上面的JSON数据结构在每一个item details中都有order no嵌套,必须在所有的order number里面取出来,然后是订单各自的数据。
您可以复制粘贴 运行 下面的完整代码
第一步:可以用payloadFromJson
解析,content
字段为Map<String, List<List<OrderContent>>>
,完整代码见下方
第 2 步:显示 FutureBuilder
和 ListView.separated
工作演示
完整代码
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:convert';
Payload payloadFromJson(String str) => Payload.fromJson(json.decode(str));
String payloadToJson(Payload data) => json.encode(data.toJson());
class Payload {
Payload({
this.error,
this.content,
});
String error;
Map<String, List<List<OrderContent>>> content;
factory Payload.fromJson(Map<String, dynamic> json) => Payload(
error: json["error"],
content: Map.from(json["content"]).map((k, v) =>
MapEntry<String, List<List<OrderContent>>>(
k,
List<List<OrderContent>>.from(v.map((x) =>
List<OrderContent>.from(
x.map((x) => OrderContent.fromJson(x))))))),
);
Map<String, dynamic> toJson() => {
"error": error,
"content": Map.from(content).map((k, v) => MapEntry<String, dynamic>(
k,
List<dynamic>.from(
v.map((x) => List<dynamic>.from(x.map((x) => x.toJson())))))),
};
}
class OrderContent {
OrderContent({
this.sodPk,
this.sohFk,
this.sqdFk,
this.orderHeader,
});
String sodPk;
String sohFk;
String sqdFk;
OrderHeader orderHeader;
factory OrderContent.fromJson(Map<String, dynamic> json) => OrderContent(
sodPk: json["sod_pk"],
sohFk: json["soh_fk"],
sqdFk: json["sqd_fk"],
orderHeader: OrderHeader.fromJson(json["order_header"]),
);
Map<String, dynamic> toJson() => {
"sod_pk": sodPk,
"soh_fk": sohFk,
"sqd_fk": sqdFk,
"order_header": orderHeader.toJson(),
};
}
class OrderHeader {
OrderHeader({
this.sohPk,
this.orderNo,
});
String sohPk;
String orderNo;
factory OrderHeader.fromJson(Map<String, dynamic> json) => OrderHeader(
sohPk: json["soh_pk"],
orderNo: json["order_no"],
);
Map<String, dynamic> toJson() => {
"soh_pk": sohPk,
"order_no": orderNo,
};
}
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
Future<Payload> _future;
Future<Payload> getData() async {
String jsonString = '''
{
"error": "false",
"content": {
"16": [
[
{
"sod_pk": "31688",
"soh_fk": "23660",
"sqd_fk": "33294",
"order_header": {
"soh_pk": "23660",
"order_no": "16"
}
}
],
[
{
"sod_pk": "31689",
"soh_fk": "23660",
"sqd_fk": "33293",
"order_header": {
"soh_pk": "23660",
"order_no": "16"
}
}
]
],
"18": [
[
{
"sod_pk": "31744",
"soh_fk": "23702",
"sqd_fk": "33354",
"order_header": {
"soh_pk": "23702",
"order_no": "18"
}
}
],
[
{
"sod_pk": "31745",
"soh_fk": "23702",
"sqd_fk": "33356",
"order_header": {
"soh_pk": "23702",
"order_no": "18"
}
}
]
]
}
}
''';
http.Response response = http.Response(jsonString, 200);
if (response.statusCode == 200) {
return payloadFromJson(response.body);
}
}
@override
void initState() {
_future = getData();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: FutureBuilder(
future: _future,
builder: (context, AsyncSnapshot<Payload> snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.none:
return Text('none');
case ConnectionState.waiting:
return Center(child: CircularProgressIndicator());
case ConnectionState.active:
return Text('');
case ConnectionState.done:
if (snapshot.hasError) {
return Text(
'${snapshot.error}',
style: TextStyle(color: Colors.red),
);
} else {
return ListView.separated(
separatorBuilder: (BuildContext context, int index) {
return SizedBox(
height: 30,
);
},
itemCount: snapshot.data.content.keys.length,
itemBuilder: (context, index) {
String key =
snapshot.data.content.keys.elementAt(index);
return Column(
children: [
Text(key),
ListView.separated(
separatorBuilder:
(BuildContext context, int index) {
return SizedBox(
height: 10,
);
},
shrinkWrap: true,
itemCount: snapshot.data.content[key].length,
itemBuilder: (context, index) {
return Column(
children: [
Text(snapshot
.data.content[key][index][0].sodPk),
Text(snapshot
.data.content[key][index][0].sqdFk),
Text(snapshot.data.content[key][index][0]
.orderHeader.sohPk),
],
);
},
)
],
);
});
}
}
}));
}
}
你的json没有优化好难处理。
首先,你看到你的 json['content'] 不是一个列表,所以你不能使用 foreach 来获取数据。它是一个对象(地图){...}。但是扑动不确切地知道它是什么的地图,所以你必须投射它。其次,要获得 sod_pk
例如,您必须通过 2 个列表。这是不必要的。这是代码
final content = (data['content'] as Map<String, dynamic>);
final sod_pk = content['16'].first.first['sod_pk'];
print(sod_pk);