如何在flutter中返回一个项目和项目列表

问题描述 投票:0回答:1

我构建了一个应用程序,用于从服务器返回用户信息,信息可能包含项目或项目列表,我的问题是,当我将变量定义为列表时,它返回项目列表但是当我想要时它会出错只返回一个项目,当我将变量定义为地图时,它返回一个项目,但是当我返回一个列表时它会出错,我该如何解决?

附:这是我的代码

import 'package:flutter/material.dart';
import 'package:idb/pages/aboutus.dart';
import 'package:idb/pages/logout.dart';
import 'package:idb/utilities/cardinfo.dart';
import 'package:idb/utilities/getTokenParameter.dart';
import 'package:date_range_picker/date_range_picker.dart' as DateRagePicker;
import 'package:idb/utilities/postRequest.dart';

String userid = '0000';

Future getUsername() async {
  var tokeninfo = await parseJwt();
  userid = tokeninfo['117115101114105100'];
}

class HomePage extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return HomePageState();
  }
}

class HomePageState extends State<HomePage> {
  List item;

  cardfoo() async {
    Map<String, dynamic> user = await getCards(userid);

    item = user['ResponseData']['data']['ROW'];

    if (mounted) {
      setState(() {
        item = user['ResponseData']['data']['ROW'];

        print('item: ${item}');
      });
    }
    return 'success';
  }

  getTransactions(
      String cardLast4digits, String dateFrom, String dateTo) async {
    var tokeninfo = await parseJwt();
    print(tokeninfo);
    print(cardLast4digits);

    String userid = tokeninfo['117115101114105100'];
    String username = tokeninfo['11711510111411097109101'];
    String url =
        'http://192.168.128.130:';

    final Map<String, dynamic> authData = {
      'Userid': userid,
      'Username': username,
      'Last4Digit': cardLast4digits,
      'DateFrom': dateFrom,
      'DateTo': dateTo,
    };

    print('befor post: ${authData}');

    Map<String, dynamic> responseData = await post(url, authData);

    print(responseData);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text("Home"),
        ),
        body: item == null
            ? Center(
                child: CircularProgressIndicator(),
              )
            : ListView.builder(
                itemCount: item == null ? 0 : item.length,
                scrollDirection: Axis.vertical,
                shrinkWrap: true,
                itemBuilder: (BuildContext context, int index) {
                  return new Column(
                    children: <Widget>[
                      Card(
                        margin: EdgeInsets.only(
                          top: 20,
                          left: 15,
                          right: 15,
                        ),
                        shape: RoundedRectangleBorder(
                          borderRadius: BorderRadius.circular(15.0),
                        ),
                        color: Colors.white70,
                        child: new Column(
                          children: <Widget>[

                            new Padding(
                                padding: new EdgeInsets.all(7.0),
                                child: new Column(
                                  children: <Widget>[
                                    new Row(children: <Widget>[
                                      new Padding(
                                        padding: new EdgeInsets.all(7.0),
                                        child: new Text('Embossed Name:',
                                            style: new TextStyle(
                                                fontSize: 15.0,
                                                color: Colors.orange)),
                                      ),
                                      new Padding(
                                        padding: new EdgeInsets.all(7.0),
                                        child: new Text(
                                            item[index]['EMBOSSED_NAME'],
                                            style:
                                                new TextStyle(fontSize: 15.0)),
                                      ),
                                    ]),


                      SizedBox(
                        height: 10,
                      ),
                      Column(
                        children: <Widget>[
                          Row(
                            children: <Widget>[
                              FlatButton.icon(
                                textColor: Colors.blue,
                                icon: Icon(
                                    Icons.calendar_today), //`Icon` to display
                                label: Text('Transctions'),

                                onPressed: () async {
                                  final List<DateTime> picked =
                                      await DateRagePicker.showDatePicker(
                                          context: context,
                                          initialFirstDate: new DateTime.now(),
                                          initialLastDate: (new DateTime.now())
                                              .add(new Duration(days: 7)),
                                          firstDate: new DateTime(2015),
                                          lastDate: new DateTime(2020));

                                  if (picked != null && picked.length == 2) {

                                    getTransactions(
                                        item[index]['CARD_NO'],
                                        picked[0].toString(),
                                        picked[1].toString());
                                  }
                                },
                              ),
                            ],
                          ),
                        ],
                      ),
                    ],
                  );
                },
              ));
  }

  @override
  void initState() {
    super.initState();
    this.cardfoo();
  }
}

而错误就是这样

Dart Error:未处理的异常:类型'_InternalLinkedHashMap'不是'List'类型的子类型

dart flutter
1个回答
0
投票

你在这里有一个错误:

 Map<String, dynamic> user = await getCards(userid);

这是因为getCards返回List而不是Map,所以尝试获取第一个元素,就像这样。

  Map<String, dynamic> user = (await getCards(userid))[0];
© www.soinside.com 2019 - 2024. All rights reserved.