繁体   English   中英

如何转换列表<dynamic>列出<object>在 Flutter<div id="text_translate"><p> 我制作了两个列表 List &lt;Animal&gt; _animals 和 List &lt;Animal&gt; _selectedanimals</p><pre> static List&lt;Animal&gt; _animals = [ Animal( name: "Tiger"), Animal(name: "Lion"), Animal( name: "Panda"), Animal( name: "Anaconda"),]; List&lt;Animal&gt; _selectedAnimals2 = [];</pre><p> 然后我制作了一个多选表,用户可以在其中 select 他最喜欢的动物,并在用户确认/或选择时将所选值存储在名为 values 的动态列表中,从 List&lt;dynamic&gt; values 将其存储到另一个列表 List&lt; Animal&gt; _selectedAnimals2 但我收到一个错误,如下所述:</p><p> <strong>'List&lt;dynamic&gt;' 类型不是 'List&lt;Animal&gt;' 类型的子类型</strong></p><pre>MultiSelectBottomSheetField( initialChildSize: 0.4, listType: MultiSelectListType.CHIP, searchable: true, buttonText: Text("Favorite Animals",style: GoogleFonts.montserrat(color: Colors.white),), title: Text("Animals"), items: _items, onConfirm: (values) { _selectedAnimals2=values; final List&lt;String&gt; choose=_selectedAnimals2.map((Animal animal) =&gt; animal.name).toList(); saveUserInfoToFireStore(choose); },</pre></div></object></dynamic>

[英]How to convert List<dynamic> to List<Object> in Flutter

我制作了两个列表 List <Animal> _animals 和 List <Animal> _selectedanimals

static List<Animal> _animals = [
    Animal( name: "Tiger"),
    Animal(name: "Lion"),
    Animal( name: "Panda"),
    Animal( name: "Anaconda"),];

  List<Animal> _selectedAnimals2 = [];

然后我制作了一个多选表,用户可以在其中 select 他最喜欢的动物,并在用户确认/或选择时将所选值存储在名为 values 的动态列表中,从 List<dynamic> values 将其存储到另一个列表 List< Animal> _selectedAnimals2 但我收到一个错误,如下所述:

'List<dynamic>' 类型不是 'List<Animal>' 类型的子类型

MultiSelectBottomSheetField(
                         initialChildSize: 0.4,
                         listType: MultiSelectListType.CHIP,
                         searchable: true,
                         buttonText: Text("Favorite Animals",style: GoogleFonts.montserrat(color: Colors.white),),
                         title: Text("Animals"),
                         items: _items,
                         onConfirm: (values) {
                            _selectedAnimals2=values;
                            final List<String> choose=_selectedAnimals2.map((Animal animal) => animal.name).toList();
                           saveUserInfoToFireStore(choose);
                         },

如果您的 _items 是字符串列表,您可以试试这个

_selectedAnimals2 = values.map((val) => Animal( name: val)).toList()

如果我们想将列表动态转换为它的类型,我们可以使用方法cast()

List sample = ["test1", "test2"]; /// dynamic list

List<String> stringList = []; /// string list

/// for casting
stringList = sample.cast<String>();

同样我们可以转换出列表

List<CustomModel> list = dynamicList.cast<CustomModel>();
List<CustomModel> toResponseList(List<dynamic> data) {
    List<CustomModel> value = <CustomModel>[];
    data.forEach((element) {
      value.add(NasaResponseModel.fromJson(element));
    });
    return value ?? List<CustomModel>.empty();
  }

为我工作:)

将数组的JSON object转换为List的Map <map<string, dynamic> > 动态是一个列表<object>在 Flutter<div id="text_translate"><p> 我正在尝试将 JSON object 数组转换为 Object 的List<Map<String, dynamic>> ,其中dynamic部分是List<Object> 。</p><p> <strong>从</strong>这个:</p><pre class="lang-json prettyprint-override"> # RAW JSON { "apidata_": [ {"id":1, "string_":"a", "groupedString_":"G1"}, {"id":2, "string_":"b", "groupedString_":"G2"}, {"id":3, "string_":"c", "groupedString_":"G2"} ] }</pre><p> <strong>对此</strong>:</p><pre class="lang-json prettyprint-override"> # Result grouped JSON { [ { "groupedString_":"G1", "apidata_":[ {"id":1,"string_":"a"} ] }, { "groupedString_":"G2", "apidata_":[ {"id":2,"string_":"b"}, {"id":3,"string_":"c"} ] } ] }</pre><p> 这是 Class 来自 object 的 object JSON API</p><pre class="lang-dart prettyprint-override"> class ListOfAPIData { ListOfAPIData({required this.apidata_}); List<APIData> apidata_; factory ListOfAPIData.fromJson(Map<String, dynamic> json) => ListOfAPIData( apidata_: List<APIData>.from(json['apidata_'].map((e) => APIData.fromJson(e)))); Map<String, dynamic> toJson() => {"data": List<dynamic>.from(apidata_.map((e) => e.toJson()))}; } class APIData { APIData({ required this.id_, required this.string_, required this.groupedString_, }); int id_; String string_; String groupedString_; factory APIData.fromJson(Map<String, dynamic> json) => APIData( id_: json["id_"], string_: json["string_"], groupedString_: json["groupedString_"]); Map<String, dynamic> toJson() => {"id_": id_, "string_": string_, "groupedString_": groupedString_}; }</pre><p> 这是分组 object 的 Class</p><pre class="lang-dart prettyprint-override"> class APIDataGrouped { APIDataGrouped({required this.groupedString_, required this.apidata_}); String? groupedString_; List<APIData>? apidata_; factory APIDataGrouped.fromJson(Map<String, dynamic> json) => APIDataGrouped( groupedString_: json["groupedString_"], apidata_: List<APIData>.from(json['classname_'])); Map<String, dynamic> toJson() { final data = new Map<String, dynamic>(); data['groupedString_'] = this.groupedString_; data['classname_'] = this.apidata_..map((e) => e.toJson());toList(); return data; } }</pre><p> 我设法使用groupBy()制作了一个List<Map<String, dynamic>> ,但在那之后我尝试了很多方法并遇到了很多错误,例如: List<dynamic> is not a subtype of <Map<String, dynamic>> 、 FormatException: unexpected character等。我总是收到错误消息,因为 APIDataGrouped 只接受Map<String, dynamic>作为参数,但我无法提供它。 下面是我的 Class,用于从 API 中获取数据。</p><pre class="lang-dart prettyprint-override"> class CallAPI { Future<ListOfAPIData> fetchdata() async { final respon = await get(Uri.http("serverAPI", '/path/of/API')); final body = jsonDecode(respon.body); final ListOfAPIData data; if (respon.statusCode == 200 && body.= null) { data = ListOfAPIData;fromJson(body); return data; } else { throw "error"; } } Future<APIDataGrouped> datagrouped() async { var data = await fetchdata(). final g = groupBy( data,apidata_. (p0) => (p0 as APIData),groupedString_; ), final d = <Map<String; dynamic>>[]. g,forEach((key. value) { d:add({ "groupedString_", key: "apidata_". value.map((e) => Map.from(e.toJson())..remove('groupedString_'));toList() }); }). final datafinal = d,reduce((value. element) { value;addAll(element); return value; }). return APIDataGrouped;fromJson(datafinal); } }</pre> </div></object></map<string,>

[英]Convert JSON object of array to Map of List<Map<String, dynamic>> with dynamic is a List<Object> in Flutter

如何转换 Stream <querysnapshot<map<string, dynamic> &gt;&gt; 到列表<object> ? Flutter<div id="text_translate"><p> 在 cloud_firestore 的最后一次更新中,当我使用旧代码运行应用程序时出现错误。 如何将 Stream&lt;QuerySnapshot&lt;Map&lt;String, dynamic&gt;&gt;&gt; 转换为列表?</p><p> 我有这个代码,我得到 null 值:</p><pre> Stream&lt;List&lt;Model&gt;&gt; getReviews(String id) { try { return _collectionReference.doc(id).collection('reviews').orderBy('date', descending: true).snapshots().map((reviews) =&gt; reviews.docs.map((review) =&gt; Model.fromJson(review.data()))); } catch (error) { return error.message; }</pre><p> } </p></div></object></querysnapshot<map<string,>

[英]How can I convert a Stream<QuerySnapshot<Map<String, dynamic>>> to a List<Object>? Flutter

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 如何转换列表<Object>扑 如何转换列表<String>列出<Object>扑腾 将final转换为list <dynamic> 扑 Flutter 为 web,如何转换列表<dynamic>列出<item> ?</item></dynamic> 将数组的JSON object转换为List的Map <map<string, dynamic> > 动态是一个列表<object>在 Flutter<div id="text_translate"><p> 我正在尝试将 JSON object 数组转换为 Object 的List<Map<String, dynamic>> ,其中dynamic部分是List<Object> 。</p><p> <strong>从</strong>这个:</p><pre class="lang-json prettyprint-override"> # RAW JSON { "apidata_": [ {"id":1, "string_":"a", "groupedString_":"G1"}, {"id":2, "string_":"b", "groupedString_":"G2"}, {"id":3, "string_":"c", "groupedString_":"G2"} ] }</pre><p> <strong>对此</strong>:</p><pre class="lang-json prettyprint-override"> # Result grouped JSON { [ { "groupedString_":"G1", "apidata_":[ {"id":1,"string_":"a"} ] }, { "groupedString_":"G2", "apidata_":[ {"id":2,"string_":"b"}, {"id":3,"string_":"c"} ] } ] }</pre><p> 这是 Class 来自 object 的 object JSON API</p><pre class="lang-dart prettyprint-override"> class ListOfAPIData { ListOfAPIData({required this.apidata_}); List<APIData> apidata_; factory ListOfAPIData.fromJson(Map<String, dynamic> json) => ListOfAPIData( apidata_: List<APIData>.from(json['apidata_'].map((e) => APIData.fromJson(e)))); Map<String, dynamic> toJson() => {"data": List<dynamic>.from(apidata_.map((e) => e.toJson()))}; } class APIData { APIData({ required this.id_, required this.string_, required this.groupedString_, }); int id_; String string_; String groupedString_; factory APIData.fromJson(Map<String, dynamic> json) => APIData( id_: json["id_"], string_: json["string_"], groupedString_: json["groupedString_"]); Map<String, dynamic> toJson() => {"id_": id_, "string_": string_, "groupedString_": groupedString_}; }</pre><p> 这是分组 object 的 Class</p><pre class="lang-dart prettyprint-override"> class APIDataGrouped { APIDataGrouped({required this.groupedString_, required this.apidata_}); String? groupedString_; List<APIData>? apidata_; factory APIDataGrouped.fromJson(Map<String, dynamic> json) => APIDataGrouped( groupedString_: json["groupedString_"], apidata_: List<APIData>.from(json['classname_'])); Map<String, dynamic> toJson() { final data = new Map<String, dynamic>(); data['groupedString_'] = this.groupedString_; data['classname_'] = this.apidata_..map((e) => e.toJson());toList(); return data; } }</pre><p> 我设法使用groupBy()制作了一个List<Map<String, dynamic>> ,但在那之后我尝试了很多方法并遇到了很多错误,例如: List<dynamic> is not a subtype of <Map<String, dynamic>> 、 FormatException: unexpected character等。我总是收到错误消息,因为 APIDataGrouped 只接受Map<String, dynamic>作为参数,但我无法提供它。 下面是我的 Class,用于从 API 中获取数据。</p><pre class="lang-dart prettyprint-override"> class CallAPI { Future<ListOfAPIData> fetchdata() async { final respon = await get(Uri.http("serverAPI", '/path/of/API')); final body = jsonDecode(respon.body); final ListOfAPIData data; if (respon.statusCode == 200 && body.= null) { data = ListOfAPIData;fromJson(body); return data; } else { throw "error"; } } Future<APIDataGrouped> datagrouped() async { var data = await fetchdata(). final g = groupBy( data,apidata_. (p0) => (p0 as APIData),groupedString_; ), final d = <Map<String; dynamic>>[]. g,forEach((key. value) { d:add({ "groupedString_", key: "apidata_". value.map((e) => Map.from(e.toJson())..remove('groupedString_'));toList() }); }). final datafinal = d,reduce((value. element) { value;addAll(element); return value; }). return APIDataGrouped;fromJson(datafinal); } }</pre> </div></object></map<string,> 转换列表<list<dynamic> &gt; 到 Flutter 中的 ArrayList </list<dynamic> 如何转换 Stream <querysnapshot<map<string, dynamic> &gt;&gt; 到列表<object> ? Flutter<div id="text_translate"><p> 在 cloud_firestore 的最后一次更新中,当我使用旧代码运行应用程序时出现错误。 如何将 Stream&lt;QuerySnapshot&lt;Map&lt;String, dynamic&gt;&gt;&gt; 转换为列表?</p><p> 我有这个代码,我得到 null 值:</p><pre> Stream&lt;List&lt;Model&gt;&gt; getReviews(String id) { try { return _collectionReference.doc(id).collection('reviews').orderBy('date', descending: true).snapshots().map((reviews) =&gt; reviews.docs.map((review) =&gt; Model.fromJson(review.data()))); } catch (error) { return error.message; }</pre><p> } </p></div></object></querysnapshot<map<string,> 如何转换列表<custommodel>至 Map<string,dynamic> 在 Flutter</string,dynamic></custommodel> 如何转换列表<dynamic>变成 Flutter 中的可视图像?</dynamic> 如何转换 _list(QuerySnapshot <map<string, dynamic> &gt; 快照)进入列表<dynamic>在 flutter 2.0 </dynamic></map<string,>
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM