gpt4 book ai didi

json - Flutter List JSON 到 Widget

转载 作者:IT王子 更新时间:2023-10-29 06:49:57 34 4
gpt4 key购买 nike

我在 Assets 文件夹中有一个 JSON 文件

States.json

{
"name" : "State List",
"states" : [
"Johor",
"Kedah",
"Kelantan",
"Kuala Lumpur",
"Melaka",
"Negeri Sembilan",
"Pulau Pinang",
"Perak",
"Perlis",
"Pahang",
"Terengganu",
"Sabah",
"Sarawak",
"Selangor",
"Wilayah Persekutuan"
]
}

我为各州制作了一个模型类:

state_model.dart

class States{

String name;
List<String> states;

States({this.name, this.states});

factory States.fromJson(Map<String, dynamic> json){

var statesJson = json["states"];
List<String> stateList = new List<String>.from(statesJson);

return States(
name: json["name"],
states: stateList
);
}
}

这是 ma​​in.dart 文件:

import 'package:flutter/material.dart';
import 'package:flutter/services.dart' show rootBundle;
import 'dart:async' show Future;
import 'dart:convert';
import 'package:state_json/model/state_model.dart';

//get the assets
Future<String> loadAssets() async{
return await rootBundle.loadString('assets/states.json');
}

//get the states from the assets
Future loadStates() async{
String jsonState = await loadAssets();
final jsonResponse = json.decode(jsonState);

States states = new States.fromJson(jsonResponse);
print(states.states);
return states.states;
}

void main() {
runApp(new MyApp());
}

class MyApp extends StatefulWidget {
@override
MyAppState createState() {
return new MyAppState();
}
}

class MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
return new MaterialApp(
home: new Scaffold(
appBar: new AppBar(
title: new Text("States JSON")
),
body: new FutureBuilder(
future: loadStates(),
builder: (context, snapshot){
if(snapshot.hasData){
return new ListView.builder(
itemBuilder: (context, index){
new ListTile(
title: new Text("${snapshot.data}"),
);
});
}else{
return new Center(child: new CircularProgressIndicator());
}
})
)
);
}
}

我目前面临的问题是,我可以在终端中打印出字符串的值。

I/flutter (16482): [Johor, Kedah, Kelantan, Kuala Lumpur, Melaka, Negeri Sembilan, Pulau Pinang, Perak, Perlis, Pahang, Terengganu, Sabah, Sarawak, Selangor, Wilayah Persekutuan]

但我不知道如何将这些值插入到 FutureBuilder.builder 中,它会转到 ListView.builder,然后再插入到 ListTile 中以显示状态列表。

非常感谢任何帮助。

最佳答案

这里可能有两个问题:

  1. 没有 return itemBuilder 中的声明.所以它返回 null .
  2. loadStates() 的返回类型是 Future .我认为它 应该是 Future<List<String>> .

然后就可以通过索引访问数据了:

return new ListView.builder(
itemBuilder: (context, index){
if(index >= snapshot?.data?.length ?? 0) return null;

return new ListTile(
title: new Text("${snapshot.data[index]}"),
);
});

注意:我没有测试代码。

关于json - Flutter List<String> JSON 到 Widget,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52147063/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com