Flutter從入門(mén)到寫(xiě)出完整App Day17

20.4.8 三

繼續(xù)講項(xiàng)目
點(diǎn)擊按鈕彈出Drawer
應(yīng)該是覆蓋上底部欄
下課試著做了出來(lái)
很簡(jiǎn)單

思路:
之前drawer寫(xiě)在JHHomeScreen中
包含下面的是MainScreen
給JHMainScreen一個(gè)drawer
導(dǎo)航上的按鈕是屬于JHHomeScreen
事件傳遞, 剛好是上層的

還有一個(gè)功能沒(méi)有做, 過(guò)濾
一些食品不喜歡, 過(guò)濾掉
學(xué)習(xí)思想, 項(xiàng)目架構(gòu)的思路

底部模態(tài)出選擇界面
創(chuàng)建filter文件夾, filter.dart
JHFilterScreen
filter_content.dart, JHFilterContent
路由, 默認(rèn)的方式彈出, push
自定義, 從下面彈出
generateRoute做一個(gè)監(jiān)聽(tīng)
如果setting.name == ... 做一些自定義
統(tǒng)一管理
改路由, 需要HotRestart

上面是固定
下面是滾動(dòng)列表
Column布局, 下半部占據(jù)剩余所有空間
Widget buildChoiceTitle() {}

Widget buildChoiceSelect() {}
返回一個(gè)ListView
hasSize報(bào)錯(cuò), shrinkWrap不用了, 換個(gè)寫(xiě)法
Expanded包裹一個(gè)ListView,
重復(fù)的東西抽取
Widget buildListTitle(String title, String subtitle, Function onChange)

布局完成后做一些事情
選中, 做過(guò)濾
三個(gè)界面
布爾類(lèi)型, 值在多個(gè)界面進(jìn)行共享
數(shù)據(jù)保存在哪里合適?
=> Provider MealViewModel
這樣做會(huì)出現(xiàn)問(wèn)題
相互依賴(lài), 耦合性太過(guò), 只是想使用布爾類(lèi)型, 卻要依賴(lài)整個(gè)ViewModel

=> 再搞一個(gè)FilterViewModel

生成setter嘲驾、getter, 快捷生成
Switch的value不要寫(xiě)死, 根據(jù)之前的選擇顯示

對(duì)meals數(shù)據(jù)進(jìn)行一個(gè)過(guò)濾 _meals.where((meal) {
//過(guò)濾
}).toList();
相互依賴(lài), 改一個(gè)代碼 JHMealViewModel依賴(lài)JHFilterViewModel
main.dart
ChangeNotifierProxyProvider
刪除JHMealViewModel,
有個(gè)update必傳參數(shù)
ChangeNotifierProxyProvider(
create: (ctx) => JHMealViewModel(),
update: (ctx, filterVM, mealVM) {

}

)

meal_view_model中
搞一個(gè)全局變量
void updateFilters(JHFilterViewModel filterVM) {
}
前面對(duì)返回false, 最終return true;

收藏沒(méi)有過(guò)濾掉,
如果需求就是這樣就沒(méi)有問(wèn)題
如果收藏也需要過(guò)濾掉
JHFavorViewModel依賴(lài)JHFilterViewModel
代碼都是拷貝的, 重復(fù)代碼 => 抽取
兩個(gè)類(lèi)里面有重復(fù)代碼 => 搞一個(gè)基類(lèi)
class BaseMealViewModel extends ChangeNotifer
notifyListenses()放在基類(lèi)中

過(guò)濾之后的meals生成新的對(duì)象

在搞一個(gè)getter, 拿原始的meals
originMeals {
return _meals;
}

多個(gè)Provider之間相互的依賴(lài)

Flutter沒(méi)有iOS中的ViewWillAppear

K appstore---大象期貨

國(guó)際化

i18n
在寫(xiě)一個(gè)簡(jiǎn)單的例子, 新建一個(gè)項(xiàng)目

想要做國(guó)際化, 根據(jù)當(dāng)前系統(tǒng)的語(yǔ)言
點(diǎn)擊按鈕顯示時(shí)間選擇器
里面的文本默認(rèn)顯示英文
希望在不同語(yǔ)言下顯示不同語(yǔ)言
當(dāng)前的語(yǔ)言就是中文, 沒(méi)有顯示中文
國(guó)際化的依賴(lài)
flutter:
sdk: flutter
flutter_localizations:
sdk: flutter

supportedLocales: [
Local("zh"),
Locale("en")
]
告訴Widget需要國(guó)際化
設(shè)置delegate
localizationsDelegates: [
GlobalWidgetsLocalizations.delegate
]

iOS非常的特殊
需要修改info.plist文件

i18n文件夾放所有國(guó)際化相關(guān)的東西
localizations.dart
class JHLocalizations {
static Map<String, Map<String, String>>
}
初始化對(duì)象的時(shí)候傳入一個(gè)local

localizations.dart

創(chuàng)建一個(gè)實(shí)例, 共享一個(gè)實(shí)例
參考MaterialApp的做法

isSupport判斷是否支持
顯示默認(rèn)的語(yǔ)言
shouldReload有點(diǎn)不好理解
load方法, 真正加載數(shù)據(jù)
資源是異步加載的, 返回Future

localizations_delegate.dart

抽取
static JHLocalization of(BuildContext context)

數(shù)據(jù)如果是放在服務(wù)器或json文件中, 異步加載
以json來(lái)舉例子

  1. 加載json文件
  2. 對(duì)json進(jìn)行解析
    cast函數(shù)

抽到j(luò)son文件中還不是最優(yōu)的方案
getter還是要手動(dòng)寫(xiě)
最優(yōu)的方案: 將數(shù)據(jù)抽到arb文件中(應(yīng)用資源包)
開(kāi)發(fā)時(shí)依賴(lài)
AS的IDE插件
arb文件支持傳參數(shù)
執(zhí)行了shell腳本

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末箕宙,一起剝皮案震驚了整個(gè)濱河市辨泳,隨后出現(xiàn)的幾起案子烦味,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異出革,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)渡讼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)骂束,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人成箫,你說(shuō)我怎么就攤上這事展箱。” “怎么了伟众?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,011評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)召廷。 經(jīng)常有香客問(wèn)我凳厢,道長(zhǎng)账胧,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,755評(píng)論 1 294
  • 正文 為了忘掉前任先紫,我火速辦了婚禮治泥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘遮精。我一直安慰自己居夹,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布本冲。 她就那樣靜靜地躺著准脂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪檬洞。 梳的紋絲不亂的頭發(fā)上狸膏,一...
    開(kāi)封第一講書(shū)人閱讀 51,610評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音添怔,去河邊找鬼湾戳。 笑死,一個(gè)胖子當(dāng)著我的面吹牛广料,可吹牛的內(nèi)容都是我干的砾脑。 我是一名探鬼主播,決...
    沈念sama閱讀 40,352評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼艾杏,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼韧衣!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起糜颠,我...
    開(kāi)封第一講書(shū)人閱讀 39,257評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤汹族,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后其兴,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體顶瞒,經(jīng)...
    沈念sama閱讀 45,717評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評(píng)論 3 336
  • 正文 我和宋清朗相戀三年元旬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了榴徐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,021評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡匀归,死狀恐怖坑资,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情穆端,我是刑警寧澤袱贮,帶...
    沈念sama閱讀 35,735評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站体啰,受9級(jí)特大地震影響攒巍,放射性物質(zhì)發(fā)生泄漏嗽仪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評(píng)論 3 330
  • 文/蒙蒙 一柒莉、第九天 我趴在偏房一處隱蔽的房頂上張望闻坚。 院中可真熱鬧,春花似錦兢孝、人聲如沸窿凤。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,936評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)雳殊。三九已至,卻和暖如春喷市,著一層夾襖步出監(jiān)牢的瞬間相种,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,054評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工品姓, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留寝并,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,224評(píng)論 3 371
  • 正文 我出身青樓腹备,卻偏偏與公主長(zhǎng)得像衬潦,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子植酥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評(píng)論 2 355