json - 无法在颤动中将json转换为listview
问题描述
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:async';
import 'dart:convert';
class HomePage extends StatefulWidget {
@override
HomePageState createState() => HomePageState();
}
class HomePageState extends State<HomePage> {
List items;
Future<String> getData() async {
var response = await http.get(
'https://api.torn.com/torn/?selections=items&key=7PnSA9HkVB5B6eAK');
this.setState(() {
Map items = json.decode(response.body);
print(items);
});
}
@override
void initState() {
this.getData();
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: ListView.builder(
itemCount: items == null ? 0 : items.length,
itemBuilder: (BuildContext context, int index) {
return Card(
child: Text(items[index]['name']),
);
},
),
);
}
}
据我所知,我们可以通过两种形式获取 Json,第一种是 List,第二种是 Map。就我而言,我收到了一张包含我需要的所有数据的地图,但不幸的是我不知道如何正确显示它。从打印我收到数据,但屏幕上没有任何反应。
解决方案
检查方法中的 setState getData
,您正在创建一个新items
变量而不是为其分配新值。试试这个。
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
class HomePage extends StatefulWidget {
@override
HomePageState createState() => HomePageState();
}
class HomePageState extends State<HomePage> {
Map items = {};
Future<void> getData() async {
http.Response res = await http.get(
"https://api.torn.com/torn/?selections=items&key=7PnSA9HkVB5B6eAK",
);
setState(() => items = jsonDecode(res.body)["items"]);
print(items);
}
@override
void initState() {
getData();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: ListView.builder(
itemCount: items.length,
itemBuilder: (context, index) {
index++;
return Card(
child: Text(items[index.toString()]["name"] ?? "Empty"),
);
},
),
);
}
}
推荐阅读
- json - 使用 api 版本 4 设置谷歌表的标题
- netlogo - NETLOGO:海龟拥有,除了品种1
- javascript - 为什么 svg 文本无法选择?
- pcap - 对于.pcap 文件,交换的magic_number 0xd4c3b2a1 是否影响网络数据包?
- php - php sql上传图片到登录用户
- excel - 在 Excel 上强制按时间格式排序
- python - KML 中的圆形多边形仅在预览中显示
- typescript - 如何使用 allman 大括号样式在单行 if 语句中强制换行
- javascript - 变更事件
- javascript - 在Javascript中将不同的字符串转换为snake_case