Flutter?模型動態(tài)化賦值研究分析
一、需求來源
之前無論是做 iOS 開發(fā)還是 JS 開發(fā),模型動態(tài)賦值都是一個非常重要且高頻使用的特性。進行 flutter 開發(fā)時需要用到這個特性但是不支持就感覺特別難受,遂想自己實現(xiàn)這個特性,中間經(jīng)過三個月的思考學(xué)習(xí),實現(xiàn)了一個初步方案(大家如果有更好的方案可以貼在評論里,共同進步)。
二、實現(xiàn)思路
通過重載 [] 和 []= 運算符,讓模型具備像字典一樣讀寫值的方式;
- 類中實現(xiàn)編碼和解碼方法備用:
/// 編碼 Map<String, Object?>toJson() /// 解碼 ... fromJson(Map<String, Object?>? map)
實現(xiàn)
1、在運算符 [] 方法中用對象的編碼方法 toJson 獲取到對應(yīng)的 Map 讀取對應(yīng)屬性值即可;
2、在運算符 []= 方法中對比傳入的 key,相同則賦值;
三、使用示例
var model = AppModel( appIcon: "assets/icon_light_unselected.png", appSize: "53.2M", appName: "QQ音樂 - 讓生活充滿音樂", appDate: "13:50", appDescription: """【全新設(shè)計 純凈享受】 -重塑全新視覺,輕盈/純凈/無擾/為Mac系統(tǒng)量身設(shè)計,從內(nèi)而外純凈享受; -全新結(jié)構(gòu)設(shè)計,整體交互優(yōu)化/人性化和易用性大提升,操作體驗豪華升級"; """, appVersion: "版本 7.6.0", isShowAll: false ); print("appName before: ${model["appName"]}");//appName before: QQ音樂 - 讓生活充滿音樂 model["appName"] = "哈哈哈哈"; print("appName after: ${model["appName"]}");//appName after: 哈哈哈哈
四、實現(xiàn)源碼
///升級模型 class AppModel { AppModel({ this.appIcon = "-", this.appSize = "-", this.appName = "-", this.appDate = "-", this.appDescription = "-", this.appVersion = "-", this.isShowAll = false, }); /// App圖標(biāo) String appIcon; /// App名稱 String appName; /// App大小 String appSize; /// App更新日期 String appDate; /// App更新文案 String appDescription; /// App版本 String appVersion; /// App更新文案 bool isShowAll; static AppModel? fromJson(Map<String, Object?>? map) { if (map == null) { return null; } return AppModel( appIcon: map["appIcon"].toString(), appSize: map["appSize"].toString(), appName: map["appName"].toString(), appDate: map["appDate"].toString(), appDescription: map["appDescription"].toString(), appVersion: map["appVersion"].toString(), isShowAll: map["isShowAll"] as bool, ); } Map<String, Object?>toJson() { return { "appIcon": this.appIcon, "appSize": this.appSize, "appName": this.appName, "appDate": this.appDate, "appDescription": this.appDescription, "appVersion": this.appVersion, "isShowAll": this.isShowAll, }; } Object? operator [](String key){ final map = this.toJson(); final result = map[key]; return result; } void operator []=(String key, dynamic value){ switch (key) { case "appName": this.appName = value; break; case "appIcon": this.appIcon = value; break; case "appSize": this.appSize = value; break; case "appName": this.appName = value; break; case "appDate": this.appDate = value; break; case "appDescription": this.appDescription = value; break; case "appVersion": this.appVersion = value; break; case "isShowAll": this.isShowAll = value; break; default: break; } } }
總結(jié)
1、已經(jīng)初步實現(xiàn)了模型的屬性的動態(tài)化讀寫;
2、賦值操作符中的方法實現(xiàn)太繁瑣(沒有找到其他方法),改進思考:通過 json 轉(zhuǎn)模型的插件二次開發(fā)自動生成如何?;
3、雖然已經(jīng)有了初步實現(xiàn),但是實現(xiàn)的方法還不完美不優(yōu)雅
以上就是Flutter 模型動態(tài)化賦值研究分析的詳細(xì)內(nèi)容,更多關(guān)于Flutter 模型動態(tài)化賦值的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
iOS 委托與文本輸入(內(nèi)容根據(jù)iOS編程編寫)
這篇文章主要介紹了iOS 委托與文本輸入(內(nèi)容根據(jù)iOS編程編寫) 的相關(guān)資料,需要的朋友可以參考下2016-09-09iOS開發(fā)網(wǎng)絡(luò)編程之?dāng)帱c續(xù)傳
在下載較大的文件的時候,一次不能下載完畢,這就需要用到斷點續(xù)傳,那么在IOS開發(fā)中該如何實現(xiàn)呢,下面跟著小編一起通過本文來學(xué)習(xí)下。2016-08-08iOS APP實現(xiàn)微信H5支付示例總結(jié)
這篇文章主要介紹了iOS APP實現(xiàn)微信H5支付示例總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02