大佬教程收集整理的这篇文章主要介绍了将数据从firebase序列化为Flutter的Dart对象的最佳方法是什么?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
你如何从firebase序列化这些数据?:
{ "-KiRg_F-qC59xxlfZ6ej": { "first":"Brandon","last":"Donnelson" },"-KiRgmsISBsJSWfXhrdD": { "first":"DAnny","last":"Kirk" } }
我想出了什么:(见_loadData())
import 'dart:convert'; import 'package:Flutter/material.dart'; import 'package:Flutter/services.dart'; void main() { runApp(new MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return new MaterialApp( title: 'Flutter Demo',theme: new ThemeData( priMarySwatch: Colors.blue,),home: new MyHomePage(title: 'Flutter Demo Home Page'),); } } class MyHomePage extends StatefulWidget { MyHomePage({Key key,this.titlE}) : super(key: key); final String title; @override _MyHomePageState createState() => new _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { @override Widget build(BuildContext context) { return new Scaffold( appBar: new AppBar( title: new Text(widget.titlE),body: new Center( child: new Text( 'click',floaTingActionButton: new FloaTingActionButton( onPressed: _test,tooltip: 'Increment',child: new Icon(Icons.add),); } void _test() { _loadData(); } _loadData() async { String url = 'https://dev-xxxxxxx.firebaseio.com/names.json'; var httpClient = createhttpClient(); var response = await httpClient.read(url); print('response=' + responsE); // response={"-KiRg_F-qC59xxlfZ6ej":{"first":"Brandon","last":"Donnelson"},"-KiRgmsISBsJSWfXhrdD":{"first":"DAnny","last":"Kirk"}} NamesData namesData = new NamesData(JSON.decode(responsE)); print("names.len=" + namesData.names.length.toString()); } } class NamesData { final List<NameData> names = new List(); NamesData(Map data) { data.values.forEach((Map map) => names.add(new NameData.fromJson(map))); } } class NameData { String first; String last; NameData.fromJson(Map map) { first = map['first']; last = map['last']; } }
我发现json解码器有一个更好的方法来使用reviver函数实例化类.这感觉好多了,但我想我可以做得更好.
_loadData() async { String url = 'https://dev-xxxxxxx.firebaseio.com/names.json'; var httpClient = createhttpClient(); var response = await httpClient.read(url); print('response=' + responsE); // response={"-KiRg_F-qC59xxlfZ6ej":{"first":"Brandon","last":"Kirk"}} var extendedJson = new JsonCodec(reviver: _reviver); var o = extendedJson.decode(responsE); print('end'); } // https://github.com/dart-lang/sdk/blob/master/tests/lib/convert/json_toEncodable_reviver_test.dart _reviver(key,value) { if (value != null && value is Map && key.toString().contains("-")) { return new NameData2(value); } return value; } } class NameData2 { String first; String last; NameData2(Map map) { first = map['first']; last = map['last']; } }
import 'dart:convert'; void main() { final decoder = const FirebasenamesDecoder(); print(decoder.convert(exampleFirebaseData)); } class NamedData { final String id; final String firstName; final String lastName; const NamedData(this.id,this.firstName,this.lastName); @override String toString() => '$NamedData {$id: $firstName $lastNamE}'; } class FirebasenamesDecoder extends Converter<Map,Iterable<NamedData>> { const FirebasenamesDecoder(); @override Iterable<NamedData> convert(Map<String,Map> raw) { return raw.keys.map((id) => new NamedData(id,raw[id]['first'],raw[id]['last'])); } } final exampleFirebaseData = { "-KiRg_F-qC59xxlfZ6ej": { "first":"Brandon","last":"Donnelson" },"last":"Kirk" } };
结果是:
以上是大佬教程为你收集整理的将数据从firebase序列化为Flutter的Dart对象的最佳方法是什么?全部内容,希望文章能够帮你解决将数据从firebase序列化为Flutter的Dart对象的最佳方法是什么?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。