Список Flutter JSON не возвращается должным образом

Я слежу за это видео на YouTube, чтобы помочь мне вернуть данные из онлайн-файла JSON в представление списка. Я немного изменил код, в том числе изменил URL-адрес файла JSON, и из-за этого код теперь запрашивает другие данные.

Что-то мне подсказывает, что тип JSON, который я хочу использовать, несовместим с кодом, который я использовал, но я не знаю почему и могу ошибаться. Я использую исходный StarWarsData ',' StarWarsState ', который автор предоставленного видео использовал, чтобы минимизировать различия в моем коде.

Спасибо Джейк

import 'package:flutter/material.dart';
import 'dart:async';
import 'dart:convert';
import 'package:http/http.dart' as http;

void main() {
  runApp(MaterialApp(
    home: StarWarsData(),
  ));
}

class StarWarsData extends StatefulWidget {
  @override
  StarWarsState createState() => StarWarsState();
}

class StarWarsState extends State<StarWarsData> {
  final String url = "https://api.coinmarketcap.com/v2/listings/";
  List data;

  Future<String> getSWData() async {
    var res = await http
        .get(Uri.encodeFull(url), headers: {"Accept": "application/json"});

    setState(() {
      var resBody = json.decode(res.body);
      data = resBody["data"];
    });

    return "Success!";
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Star Wars Starships"),
        backgroundColor: Colors.deepPurpleAccent,
      ),
      body: ListView.builder(
        itemCount: data == null ? 0 : data.length,
        itemBuilder: (BuildContext context, int index) {
          return new Container(
            child: Center(
              child: Column(
                crossAxisAlignment: CrossAxisAlignment.stretch,
                children: <Widget>[
                  Card(
                    child: Container(
                        padding: EdgeInsets.all(15.0),
                        child: Row(
                          children: <Widget>[
                            Text("Id: "),
                            Text(data[index]["id"],
                                style: TextStyle(
                                    fontSize: 18.0, color: Colors.black87)),
                          ],
                        )),
                  ),
                  Card(
                    child: Container(
                        padding: EdgeInsets.all(15.0),
                        child: Row(
                          children: <Widget>[
                            Text("Name: "),
                            Text(data[index]["name"],
                                style: TextStyle(
                                    fontSize: 18.0, color: Colors.red)),
                          ],
                        )),
                  ),
                  Card(
                    child: Container(
                        padding: EdgeInsets.all(15.0),
                        child: Row(
                          children: <Widget>[
                            Text("Symbol: "),
                            Text(data[index]["symbol"],
                                style: TextStyle(
                                    fontSize: 18.0, color: Colors.black87)),
                          ],
                        )),
                  ),
                ],
              ),
            ),
          );
        },
      ),
    );
  }

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

РЕДАКТИРОВАТЬ

Теперь вопрос исправлен, но если кому-то было интересно, вот ошибка, с которой я столкнулся ранее:

I/flutter (31850): ══╡ EXCEPTION CAUGHT BY WIDGETS LIBRARY 
╞═══════════════════════════════════════════════════════════I/flutter 
(31850): type 'int' is not a subtype of type 'String' where I/flutter 
(31850): int is from dart:core I/flutter 
(31850): String is from dart:core

Пожалуйста, добавьте полученные сообщения об ошибках

Günter Zöchbauer 02.06.2018 16:07

На вопрос уже был дан ответ, но на всякий случай, вот ошибка. I / flutter (31850): ══╡ ИСКЛЮЧЕНИЕ, ЗАХОТЕННОЕ В БИБЛИОТЕКЕ ВИДЖЕТОВ ╞════════════════════════════════════ ═════════════════════════‌ I / flutter (31850): тип int не является подтипом типа String, где I / flutter (31850): int от dart: core I / flutter (31850): строка от dart: core

Jake 02.06.2018 16:49

Если этого недостаточно, просто следуйте за мной, у меня было мало места в моем ответе

Jake 02.06.2018 16:50

Вы можете редактировать вопрос и добавлять дополнительную информацию. Таким образом, вы также можете правильно его отформатировать.

Günter Zöchbauer 02.06.2018 16:52

Итак, вы хотите, чтобы я переформатировал вопрос или рассказал вам больше о моей ошибке? Полагаю, мне следует отредактировать свой вопрос и добавить полный журнал

Jake 02.06.2018 17:33

Я имел в виду добавить контент из вашего предыдущего комментария к вопросу вместо того, чтобы правильно отформатировать его, чтобы сделать его читабельным. Даже когда ваша проблема была решена, мы сделали ее более полезной для других, у которых возникла аналогичная проблема.

Günter Zöchbauer 02.06.2018 17:37

Хорошо, я вернусь к этому через минуту

Jake 02.06.2018 17:39
0
7
360
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Проблема здесь,

Text(data[index]["id"],

где поле "id" является целым числом, и вы используете его непосредственно вместо String.

Измените его на,

Text('${data[index]["id"]}',

Вам тоже, ваша помощь очень ценится :)

Jake 02.06.2018 17:04

Другие вопросы по теме