#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?