flutter - 如何等到列表不为空?- 颤振期货
问题描述
这是我的主屏幕代码:
class HomeScreen extends StatelessWidget {
@override
Widget build(BuildContext context) {
final enterpriseProvider = Provider.of<EnterpriseProvider>(context);
final resp = enterpriseProvider.indicator;
final List<IpcData> data = createIpcList(resp);
print(data);
return Scaffold(
appBar: AppBar(
title: Text('Hola'),
),
body: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
child: Container(
child: ResultList( formattedData: data )
),
),
],
)
);
}
createIpcList(List<List<dynamic>> resp) {
List<IpcData> ipcList = resp.map((e) => IpcData(e[0], e[1])).toList();
return ipcList;
}
}
发生的情况是“resp”值来自 http 请求。所以当我第一次调用 createIpcList(resp); 它返回一个空列表。这里的问题是我在返回的 Scaffold 中使用的 ResultList 小部件使用该数据来构建图表。当我加载应用程序时,图表是空白的,好像没有传递任何数据。我注意到当我进行热重启时,它会打印一个空列表,但几秒钟后,它会打印数据,就好像我再次调用了打印一样。问题是图表保持空白。我想提出一个条件,所以如果数据=![] 它返回我的脚手架,如果没有,它返回一个加载屏幕。我知道这可以通过 Futures 实现,但我不知道如何。一旦我有数据,我想返回脚手架,否则我的图表将永远是空的。
解决方案
为此,您必须使用FutureBuilder小部件
FutureBuilder(
future: createIpcList(resp),
builder: (context, snapshot){
if (snapshot.hasData)
return ResultList(formattedData: snapshot.data);
}
);
如果您愿意,您可以在从服务器获取数据时显示加载指示器。
推荐阅读
- java - 带通配符的类型参数
- java - Android-每次获取一个随机数并调用另一个类中的值
- google-apps-script - 触发执行>30s;没有意义
- spring-boot - 带有 AWS Kinesis 流 @refreshscope 的 Spring 云总线
- google-sheets - 单个单元格上的 Google 表格条件格式
- salesforce - jsforce 搜索不适用于使用 like 运算符的联系人
- mysql - 根据参数对查询结果进行分组和排序
- javascript - 如何使用selectize js在clear()之后在输入标签中设置值
- python - 使用 pymysql 调用 mysql 过程
- laravel-8 - 使用 withErrors([])