从api填充列表时显示加载指示器

时间:2018-10-11 07:43:05

标签: dart flutter

扑朔迷离...我正在我的应用程序中调用一个api,我想在api函数完成并且从api中检索到所有东西时显示加载指示器。如何实现此目标?

class _CompaniesPageState extends State<CompaniesPage> {
  getcompanies() async {
  var url = 'my link';
  http
    .post(url, body: json.encode({ 'token': globals.token }))
    .then((response) {
      // print("Response body: ${response.body}");
      Map data = json.decode(response.body);
      final companies =
        (data['Companies'] as List).map((i) => new Company.fromJson(i));
      setState(() {
        for (final company in companies) {
          if (!company.category.contains("الراعي") &&
            !company.category.contains("الشريك") &&
            !company.category.contains("الداعم")) {
            if (company.logo != "") {
              names.add(company.name);
              logos.add(company.logo);
            }
          }
        }
      });
    });
}

@override
Widget build(BuildContext context) {
  getcompanies();
  if (globals.isguest) {
    return new Directionality(
      .....
    );
  }

}

List<Widget> createCompaniesChildren() {
  List<Widget> children = List<Widget>();
  for (int i = 0; i < names.length; i++) {
    children.add(
      new Padding(
        padding: new EdgeInsets.only(right: 15.0, left: 15.0),
        child: new Image.network(
          logos[i],
          width: 346.0,
          height: 180.0,
        ),
      ),
    );
    children.add(
      new Padding(
        padding: new EdgeInsets.only(right: 15.0, left: 15.0),
        child: new Center(
          child: new Text(
            names[i],
            style: new TextStyle(color: Colors.black, fontSize: 17.0),
            textAlign: TextAlign.center,
          ),
        ),
      ),
    );
    children.add(new Divider());
  }
  return children;
}

如何在列表填充时显示加载指示器,然后在完成后将其关闭?

尝试过:

          body: new Padding(
        padding: new EdgeInsets.only(top: 15.0),
        child: new Center(
          child: new FutureBuilder(
            future:
                getcompanies(), // your async method that returns a future
            builder: (BuildContext context, AsyncSnapshot snapshot) {
              if (snapshot.hasData) {
                // if data is loaded
                if (snapshot.data != null) {
                  return new ListView.builder(
                    padding: new EdgeInsets.all(8.0),
                    itemExtent: 20.0,
                    itemBuilder: (BuildContext context, int i) {
                      return new Center(
                        child: new Text(
                          snapshot.data[i].name,
                          style: new TextStyle(
                              color: Colors.black, fontSize: 17.0),
                          textAlign: TextAlign.center,
                        ),
                      );
                    },
                  );
                } else {
                  // if data not loaded yet
                  return new CircularProgressIndicator();
                }
              }
            },
          ),
        ),
      ),

但出现此错误:I / flutter(31276):引发了另一个异常:构建函数返回了null。

1 个答案:

答案 0 :(得分:1)

您可以将FutureBuilder类用于此目的。

您也可以使用ListView来代替手动创建公司列表。

类似这样的东西:

new FutureBuilder(
  future: getcompanies(), // your async method that returns a future
  builder: (BuildContext context, AsyncSnapshot snapshot) {
    if (snapshot.hasData) {
      // if data is loaded
      return new ListView.builder(
        padding: new EdgeInsets.all(8.0),
        itemExtent: 20.0,
        itemCount: snapshot.data.length,
        itemBuilder: (BuildContext context, int i) {
          return new Center(
            child: new Text(
              snapshot.data[i].name,
              style: new TextStyle(color: Colors.black, fontSize: 17.0),
              textAlign: TextAlign.center,
            ),
          );
        },
      ).build(context);
    } else {
      // if data not loaded yet
      return new CircularProgressIndicator();
    }
  },
)