颤振Api响应列表动态不是未来的子类型



你好,我有一个颤振响应只是一个响应,这给了我一个产品名称从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));
});

最新更新