簡體   English   中英

從 Future 返回 object<list> 在 Flutter</list>

[英]Returning an object from Future<List> in Flutter

我正在努力將 Future 解析為 object。 我想從Future<List<User>>檢索User數據到User object。 我可以獲取 User 數據,但它仍在Future中。

Future<List<User>> getDataUser(String name_,int id_) async{
    var datajson=await Network.getData("https://jsonplaceholder.typicode.com/users?username=$name_&id=$id_");
    final response=jsonDecode(datajson);
    List<User> fuser=response.map((r)=>User.fromJson(r)).toList();
    User user_=fuser.single;
    print('response: '+user_.name);
    return fuser;
}

編輯: Network.getDataFuture<dynamic>

當我調用activeUser()時,我希望它返回一個 object ( User )。

User activeUser(Future<List<User>> fuser){
    List<User> user=fuser as List<User>;
    print('user: '+user.single.username);
    return user.single;
}

我總是收到這種error: type 'Future<List<User>>' is not a subtype of type 'List<User>'我避免使用構建器FutureBuilderListView.Builder或其他),因為我不是要做一個清單。 它只是一個 map。 我希望Future<List<User>>返回User object。 我使用的 REST API 返回一個列表,而不是 object

[
  {
    "id": 1,
    "name": "Leanne Graham",
    "username": "Bret",
    "email": "Sincere@april.biz",
    "address": {
      "street": "Kulas Light",
      "suite": "Apt. 556",
      "city": "Gwenborough",
      "zipcode": "92998-3874",
      "geo": {
        "lat": "-37.3159",
        "lng": "81.1496"
      }
    },
    "phone": "1-770-736-8031 x56442",
    "website": "hildegard.org",
    "company": {
      "name": "Romaguera-Crona",
      "catchPhrase": "Multi-layered client-server neural-net",
      "bs": "harness real-time e-markets"
    }
  }
]
  • 注意矩形括號,它是一個包含一個 json map 的列表。

嘗試這個:

var fName;
...

getDataUser(name, id).then((fuser){
    print('user: '+ fuser.single.username);
    this.fName = fuser.single;});

我已經想通了。

我創建了一個class ListUser來存儲從Future返回的列表

class ListUser{
  final List<User> oneuser;

  DaftarUser({this.oneuser});

  factory ListUser.fromJson(List<dynamic> jsonuser){
    List userone=new List();
    userone=jsonuser.map((p)=>User.fromJson(p)).toList();

    return new ListUser(
      oneuser:userone
    );
  }
}


然后我將上面的 class 稱為Future<List<User>>

Future<List<User>> getDataUser(String name_,int id_) async{
    var datajson=await Network.getData("https://jsonplaceholder.typicode.com/users?username=$name_&id=$id_");
    final response=jsonDecode(datajson);
    List<User> fuser=ListUser.fromJson(datajson).oneuser;
    // User user_=fuser.single;
    // print('response: '+user_.name);
    // those two line above are for seeing the value only, not too important
    return fuser;
}


上面的 Function 會返回一個List<User> ,這樣我就可以更改activeUser function,像這樣:

User activeUser(List<User> fuser){
    User u=fuser.single;
    return u;
}

現在我可以在任何需要的地方調用activeUser

順便說一句,感謝上面的幫助。 干杯

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM