Flutter从入门到写出完整App Day17

20.4.8 三

继续讲项目
点击按钮弹出Drawer
应该是覆盖上底部栏
下课试着做了出来
很简单

思路:
之前drawer写在JHHomeScreen中
包含下面的是MainScreen
给JHMainScreen一个drawer
导航上的按钮是属于JHHomeScreen
事件传递, 刚好是上层的

还有一个功能没有做, 过滤
一些食品不喜欢, 过滤掉
学习思想, 项目架构的思路

底部模态出选择界面
创建filter文件夹, filter.dart
JHFilterScreen
filter_content.dart, JHFilterContent
路由, 默认的方式弹出, push
自定义, 从下面弹出
generateRoute做一个监听
如果setting.name == ... 做一些自定义
统一管理
改路由, 需要HotRestart

上面是固定
下面是滚动列表
Column布局, 下半部占据剩余所有空间
Widget buildChoiceTitle() {}

Widget buildChoiceSelect() {}
返回一个ListView
hasSize报错, shrinkWrap不用了, 换个写法
Expanded包裹一个ListView,
重复的东西抽取
Widget buildListTitle(String title, String subtitle, Function onChange)

布局完成后做一些事情
选中, 做过滤
三个界面
布尔类型, 值在多个界面进行共享
数据保存在哪里合适?
=> Provider MealViewModel
这样做会出现问题
相互依赖, 耦合性太过, 只是想使用布尔类型, 却要依赖整个ViewModel

=> 再搞一个FilterViewModel

生成setter、getter, 快捷生成
Switch的value不要写死, 根据之前的选择显示

对meals数据进行一个过滤 _meals.where((meal) {
//过滤
}).toList();
相互依赖, 改一个代码 JHMealViewModel依赖JHFilterViewModel
main.dart
ChangeNotifierProxyProvider
删除JHMealViewModel,
有个update必传参数
ChangeNotifierProxyProvider(
create: (ctx) => JHMealViewModel(),
update: (ctx, filterVM, mealVM) {

}

)

meal_view_model中
搞一个全局变量
void updateFilters(JHFilterViewModel filterVM) {
}
前面对返回false, 最终return true;

收藏没有过滤掉,
如果需求就是这样就没有问题
如果收藏也需要过滤掉
JHFavorViewModel依赖JHFilterViewModel
代码都是拷贝的, 重复代码 => 抽取
两个类里面有重复代码 => 搞一个基类
class BaseMealViewModel extends ChangeNotifer
notifyListenses()放在基类中

过滤之后的meals生成新的对象

在搞一个getter, 拿原始的meals
originMeals {
return _meals;
}

多个Provider之间相互的依赖

Flutter没有iOS中的ViewWillAppear

K appstore---大象期货

国际化

i18n
在写一个简单的例子, 新建一个项目

想要做国际化, 根据当前系统的语言
点击按钮显示时间选择器
里面的文本默认显示英文
希望在不同语言下显示不同语言
当前的语言就是中文, 没有显示中文
国际化的依赖
flutter:
sdk: flutter
flutter_localizations:
sdk: flutter

supportedLocales: [
Local("zh"),
Locale("en")
]
告诉Widget需要国际化
设置delegate
localizationsDelegates: [
GlobalWidgetsLocalizations.delegate
]

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

i18n文件夹放所有国际化相关的东西
localizations.dart
class JHLocalizations {
static Map<String, Map<String, String>>
}
初始化对象的时候传入一个local

localizations.dart

创建一个实例, 共享一个实例
参考MaterialApp的做法

isSupport判断是否支持
显示默认的语言
shouldReload有点不好理解
load方法, 真正加载数据
资源是异步加载的, 返回Future

localizations_delegate.dart

抽取
static JHLocalization of(BuildContext context)

数据如果是放在服务器或json文件中, 异步加载
以json来举例子

  1. 加载json文件
  2. 对json进行解析
    cast函数

抽到json文件中还不是最优的方案
getter还是要手动写
最优的方案: 将数据抽到arb文件中(应用资源包)
开发时依赖
AS的IDE插件
arb文件支持传参数
执行了shell脚本

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343