чтение данных json с помощью двух массивов flutter

#mysql #json #flutter

#mysql #json #flutter

Вопрос:

здравствуйте, я новичок в flutter и создаю приложение, для которого требуется анализ данных json. Я успешно проанализировал простые данные json с помощью одного массива, но не сложного, поскольку я хочу проанализировать «массив папок» в моем приложении flutter. вот код для json :

 {
   "folders":[
      {
         "id":2107,
         "name":"Labs ",
         "img":null,
         "haschild":1,
         "parentid":1955,
         "createdate":"2019-09-30 03:00:39",
         "inarchive":0,
         "active":1
      },
      {
         "id":2108,
         "name":"L1",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-09-30 03:00:45",
         "inarchive":0,
         "active":1
      },
      {
         "id":2130,
         "name":"L2",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-02
02:39:11",
         "inarchive":0,
         "active":1
      },
      {
         "id":2175,
         "name":"L3",
         "img":null,
         "haschild":1,
         "parentid":1955,
         "createdate":"2019-10-07 03:43:15",
         "inarchive":0,
         "active":1
      },
      {
         "id":2202,
         "name":"L4",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-09 02:08:10",
         "inarchive":0,
         "active":1
      },
      {
         "id":2227,
         "name":"u0645u0631u0627u062cu0639u0627u062a
",
         "img":null,
         "haschild":1,
         "parentid":1955,
         "createdate":"2019-10-11 05:15:43",
         "inarchive":0,
         "active":1
      },
      {
         "id":2242,
         "name":"L5",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-14 03:45:24",
         "inarchive":0,
         "active":1
      },
      {
         "id":2257,
         "name":"L6",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-16
06:23:41",
         "inarchive":0,
         "active":1
      },
      {
         "id":2269,
         "name":"L7",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-21 03:39:12",
         "inarchive":0,
         "active":1
      },
      {
         "id":2309,
         "name":"L8",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-23 05:14:48",
         "inarchive":0,
         "active":1
      },
      {
         "id":2310,
         "name":"L8",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-23
05:14:51",
         "inarchive":0,
         "active":1
      },
      {
         "id":2346,
         "name":"L9",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-28 04:22:24",
         "inarchive":0,
         "active":1
      },
      {
         "id":2370,
         "name":"L10",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-10-30 03:02:00",
         "inarchive":0,
         "active":1
      },
      {
         "id":2446,
         "name":"L11",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-12
06:28:13",
         "inarchive":0,
         "active":1
      },
      {
         "id":2462,
         "name":"u062au0628u064au0636u0627u062a",
         "img":null,
         "haschild":1,
         "parentid":1955,
         "createdate":"2019-11-13 08:39:00",
         "inarchive":0,
         "active":1
      },
      {
         "id":2464,
         "name":"L12",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-13
08:40:55",
         "inarchive":0,
         "active":1
      },
      {
         "id":2488,
         "name":"L13",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-18 06:09:11",
         "inarchive":0,
         "active":1
      },
      {
         "id":2490,
         "name":"L14",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-18 06:38:59",
         "inarchive":0,
         "active":1
      },
      {
         "id":2491,
         "name":"L15",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-18
06:45:57",
         "inarchive":0,
         "active":1
      },
      {
         "id":2497,
         "name":"u062au0644u062eu064au0635u0627u062a",
         "img":null,
         "haschild":1,
         "parentid":1955,
         "createdate":"2019-11-19 04:24:49",
         "inarchive":0,
         "active":1
      },
      {
         "id":2509,
         "name":"L16",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-20
09:56:04",
         "inarchive":0,
         "active":1
      },
      {
         "id":2522,
         "name":"L17",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-25 06:38:27",
         "inarchive":0,
         "active":1
      },
      {
         "id":2542,
         "name":"L18",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-27 12:19:12",
         "inarchive":0,
         "active":1
      },
      {
         "id":2552,
         "name":"Protein
Lab",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-27 16:32:27",
         "inarchive":0,
         "active":1
      },
      {
         "id":2562,
         "name":"Chromatography ",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-11-30 15:24:24",
         "inarchive":0,
         "active":1
      },
      {
         "id":2576,
         "name":"L19",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-02
02:05:29",
         "inarchive":0,
         "active":1
      },
      {
         "id":2580,
         "name":"L20",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-02 08:23:48",
         "inarchive":0,
         "active":1
      },
      {
         "id":2592,
         "name":"21",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-03 06:27:24",
         "inarchive":0,
         "active":1
      },
      {
         "id":2600,
         "name":"L22",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-04
06:22:46",
         "inarchive":0,
         "active":1
      },
      {
         "id":2614,
         "name":"L23",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-04 10:03:00",
         "inarchive":0,
         "active":1
      },
      {
         "id":2640,
         "name":"L24",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-08 06:53:11",
         "inarchive":0,
         "active":1
      },
      {
         "id":2644,
         "name":"L25",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-09
05:33:07",
         "inarchive":0,
         "active":1
      },
      {
         "id":2649,
         "name":"L26",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-09 07:58:42",
         "inarchive":0,
         "active":1
      },
      {
         "id":2711,
         "name":"u0623u0633u0626u0644u0629",
         "img":null,
         "haschild":0,
         "parentid":1955,
         "createdate":"2019-12-19
05:18:11",
         "inarchive":0,
         "active":1
      }
   ],
   "files":[
      {
         "id":4542,
         "name":"Ch2-part1.m4a 27.52MB",
         "img":null,
         "uploader":"Aws",
         "url":"http://msc-mu.com/../uploaded/031020190Ch2-part1.m4a",
         "createdate":"2019-10-03 09:53:39",
         "approved":1,
         "active":1
      }
   ]
}
  

Я использую базу данных mysql, и это форматированный код json.

Ответ №1:

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

Одним из способов реализовать это было бы использовать пакеты json_serializable вместе с build_runner и использовать их вместе с парой классов (например, named Folder и folderList), которые должны содержать значения, связанные с папкой и списком папок.

Затем пусть json_serializable и build_runner генерируют методы для синтаксического анализа в json и из него.

Для документации с примерами это хороший ресурс для чтения: https://flutter.dev/docs/development/data-and-backend/json

Комментарии:

1. здравствуйте, я знаю, что я не реализовал никакого кода, но именно поэтому я отправил вопрос все, что я устал, не сработало!

2. могу ли я связаться с вами?

3. @FahmiSawalha Я добавил ссылку на хороший ресурс с примерами того, как использовать json с flutter. Это должно указать вам правильное направление.

Ответ №2:

Сначала вам нужно создать модель для вашего объекта folder

 class Folder {
     String id;
     String name;
     String img;
     // etc...
// Create constructor
// json converted
factory Folder.fromJson(Map<String, dynamic> json) {
return Folder(
  id: json['id'],
  name: json['name'],
  image: json['image'],
);
  

}

Во-вторых, вы можете сделать следующее

 List<Folder> folders = (json['folders'] as List).map((folder) => Folder.fromJson(folder)).toList();
  

Комментарии:

1. где я должен сделать второй шаг?

2. Future<List<Folder>>fellowSubject() async{ final jsonEndpoint = "http://msc-mu.com/api_verfication.php"; final response = await http.post(jsonEndpoint,body: { 'flag':'selectfellowsubjects', 'parentsubject':{widget.value.id} }); if (response.statusCode == 200) { List<Folder> folders = (json[] as List).map((folder) => Folder.fromJson(folder)).toList(); return folders; } else throw Exception('We were not able to successfully download the Main Subjects.'); }

3. да, но (json[‘folders’] как список).map нет (json[] как список).map

4. можете ли вы дать мне свой discord?