你好,我有一个颤振响应只是一个响应,这给了我一个产品名称从api
[
{
"pname":"xyz"
}
]
我想解析并显示文本字段上的pname值,我尝试了以下
Future<ProductsRequest> pnames() async {
var url= 'https:abc.com/api/p';
final response = await http.get(Uri.parse(url)).timeout(Duration(seconds: 105000));
var responseJson = json.decode(response.body);
return responseJson;
}
模型List<ProductsRequest> productsrequestFromJson(String str) => List<ProductsRequest>.from(json.decode(str).map((x) => ProductsRequest.fromJson(x)));
String productsrequestToJson(List<ProductsRequest> data) => json.encode(List<dynamic>.from(data.map((x) => x.toJson())));
class ProductsRequest {
ProductsRequest({
this.pname,
});
String pname;
factory ProductsRequest.fromJson(Map<String, dynamic> json) => ProductsRequest(
pname: json["pname"],
);
Map<String, dynamic> toJson() => {
"pname": pname,
};
}
然后在我的dart类
new FutureBuilder<ProductsRequest>(
future: pnames(""),
builder: (BuildContext context, snapshot) {....
Widget _pdisplay(ProductsRequest data) {
return Container(
child:Column(
children: [
Text(data.pname.toString()),
],
)
);
显示一个错误列表动态不是未来的子类型
首先,您在响应中得到的是一个列表。而您试图返回的只是原始响应的解码版本。
所以你需要做的就是对解码后的响应执行forEach并创建ProductsRequest列表。
像这样:
List<ProductsRequest> list = new List<ProductsRequest>();
responseJson.forEach((v) {
list.add(new ProductsRequest.fromJson(v));
});