我可以在将来的构建器上使用多种方法吗?

hey*_*red 5 dart flutter

     @override
      Widget build(BuildContext context) {
        widget.groupid;
        widget.event_id;
        var futureBuilder = new FutureBuilder(
          future: _getAllTickets(),

          builder: (BuildContext context, AsyncSnapshot snapshot) {
            print(snapshot.connectionState);
            switch (snapshot.connectionState) {
              case ConnectionState.none:
              case ConnectionState.waiting:
                return new Text('...');
              default:
                if (snapshot.hasError)
                  return new Text('Error: ${snapshot.error}');
                else
                  return createListTickets(context, snapshot);
            }
          },
        );



    return new Scaffold(

      body: futureBuilder,

    );
  }

  Widget createListTickets(BuildContext context, AsyncSnapshot snapshot) {
    List values = snapshot.data;

     child: new Card(

                child:
                new Column(mainAxisSize: MainAxisSize.min, children: <Widget>[
                  new Text(
                      values[index]["ticket_type_id"].toString(), style:
                  const TextStyle(
                      fontFamily: 'Poppins',
                      fontWeight: FontWeight.w600,
                      fontSize: 25.0)),
}


  _getAllTickets() async {
    final response = await http.get(
        "https...}"
        , headers: {
      HttpHeaders.AUTHORIZATION: access_token
    });

    returnTickets = json.decode(response.body);
    return returnTickets;
  }


  _getTicketType() async {
    for (i = 0; i < (returnTickets?.length ?? 0); i++) {
      /*print("https....);*/
     final responseType = await http.get(
          "https...}"
          , headers: {
        HttpHeaders.AUTHORIZATION: access_token
      });

      Map<String, dynamic> hey = json.decode(responseType.body);


    }
Run Code Online (Sandbox Code Playgroud)

大家好,我有一个问题。当我发送多个API请求并使用返回的响应动态构建卡时,我想知道将来是否可以包含一个以上的方法:_getAllTickets(),+(另一个方法),我想用values [index] [“ name”]替换values [index] [“ ticket_type_id”],该名称是我通过_getTicketType()方法获得的新索引响应。先感谢您!

Rém*_*let 10

您可以用来Future.wait(Future[])将期货列表合并为一个。

class Merged {
  final String foo;
  final String bar;

  Merged({this.foo, this.bar});
}

Future<String> foo;
Future<int> bar;
new FutureBuilder(
  future: Future.wait([bar, foo]).then(
    (response) => new Merged(foo: response[0], bar: response[1]),
  ),
  builder: (context, AsyncSnapshot<Merged> snapshot) {

  },
);
Run Code Online (Sandbox Code Playgroud)