首页 > 解决方案 > 如何等到列表不为空?- 颤振期货

问题描述

这是我的主屏幕代码:


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 实现,但我不知道如何。一旦我有数据,我想返回脚手架,否则我的图表将永远是空的。

标签: flutterdartmobilewidgetfuture

解决方案


为此,您必须使用FutureBuilder小部件

FutureBuilder(
    future: createIpcList(resp),
    builder: (context, snapshot){
        if (snapshot.hasData)
            return ResultList(formattedData: snapshot.data);
    }
);

如果您愿意,您可以在从服务器获取数据时显示加载指示器。


推荐阅读