最后,如果大伙有什么好的学习方法或建议欢迎大家在评论中积极留言哈,希望大家能够共同学习、共同努力、共同进步。
小编在这里祝小伙伴们在未来的日子里都可以 升职加薪,当上总经理,出任CEO,迎娶白富美,走上人生巅峰!!
不论遇到什么困难,都不应该成为我们放弃的理由!
很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习
如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
V0.1.9 2019-10-14
- 极致黑(Native的闪屏页面适配darkMode)
- 首页banner高度根据屏幕宽高适应
- 签名文件调整
V0.1.8 2019-10-13
- 文章列表加入分享人
- 首页加入数据为空的逻辑判断
- ViewStateModel中逻辑优化,bug fix
- 状态栏字体颜色优化
- 修复TextField中hint为中文时不居中的问题
V0.1.7 2019-09-23
- DarkMode自动跟随系统设置
- App更新组件调整
- 适配Dio3.0版本
- pull_to_refresh更新:加入国际化
V0.1.6 2019-09-20
- 修复收藏列表进入详情时,页面报错的bug
V0.1.5 2019-09-19
- Flutter SDK更新至Channel dev, v1.10.3,修复
我的
页面莫名卡死的问题 - 修改Android端App名称为Fun Android
V0.1.4 2019-09-18
- 适配Flutter 1.9.x
- Android加入版本更新
- 加入LeanCloud API云服务
- 移除修复首页黑屏问题的代码
官方在1.10.1版本已修复
- 移除之前屏幕适配方案,对NativeView影响过大
- 修复版本更新导致的AppBar中进度条颜色与背景色不明显的问题
- 重构Http使用方式,解耦性更好
- 首页banner高度调整
- Android状态栏透明
2019-09-10
- flutter版本更新
- 适配更新AppBar区域CupertinoActivityIndicator的主题色彩冲突
- 移除OffState和Indicator的组合使用,优化性能
- 调整textField的clear实现方式,防止报错
2019-09-09
- 修复各页面里文章 收藏 状态没有同步的问题
- 首页收藏后,其他tab页对应item的收藏状态同步
- 我的收藏页面里移除收藏.其他页面状态同步
- 登录登出后各页面收藏状态刷新
- 如果相同账号在其他平台修改过收藏状态,只需要刷新列表即可同步收藏状态.(WanAndroid接口目前存在问题)
- 优化Dropdown弹出动画
- 首页初次加载数据禁用上拉记载更多功能
- 登录页面输入框可通过回车键切换
2019-08-30
- 修复积分数值在登录后没有刷新的bug
- 修复进入Splash页面短暂黑屏的bug
- 修复未登录时,点击收藏还可以播放动画的bug
- 默认主题色调整为亮色
2019-08-29
- 添加积分记录和排行榜功能
2019-08-28
- 在设置中添加WebViewPlugin的开关
- 在详情中移除收藏后,回到收藏列表页面自动刷新
2019-08-26
- 更新收藏动画的实现方式,之前实现的方式侵入性太强,每个页面都要先隐藏一个小❤❤。现在换了路由➕Hero的思路,重新调整了Flare。显示动画一行代码就ok。(如果你运行代码之后发现,该动画与图上会有一丝丝不一致,列表项右下角的小心会闪一下.不用担心那是flutter的bug,目前在master分支已经修复.见pr-37341)
项目结构
|
|
|
| — | — |
| | |
Provider MVVM的简单使用方式
- 快速添加一个拥有下拉刷新,上拉加载更多的页面.比如开发一个
玩Android
首页列表页面
- Model
- ViewModel
- View
以上是Provider结合ViewModel的基础使用方式,考虑了App中会出现的比较全面的情况,希望大家一起探讨使用方式
另外在判断页面状态的时候,其实拿
model.viewState == ViewState.busy
会更严谨一点.为了书写方便,加了一个对应方法
这里能找到什么?
-
Provider状态管理的最佳实践,虽然Google很早就废弃了
Provide
,宣布Provider
为推荐的状态管理工具,可是在开发中,我们总是会遇到很多问题。 -
比如
Provider
的几个衍生类在具体的业务中应该怎么使用? -
页面最初需要的数据什么时候进行初始化,在哪里初始化。
-
如何将页面的几个常用状态
loading
、error
、empty
、idle
、unAuthorized
进行组合使用。 -
常用的
下拉刷新
,上拉加载更多
应如何服用才能效果更佳。 -
Widget在dispose后,
model
不再notify()。 -
清晰的代码结构。
-
让页面归页面,让业务归业务,所有的业务逻辑都在
view_model
中,Widget只关注页面本身。 -
不要再满屏幕的setState()。
-
同一页面内可以利用Flutter框架给我们提供的各种XxxBuilder,来局部刷新。
-
多层嵌套可使用前边提到的
Provider
。 -
当然颗粒度足够细的Widget,还是要使用setState()。eg: ChangeLogPage中的ChangeLogView 功能单一,刷新不会影响别的widget。
-
实现了App的基础功能,可copy当作模板代码快速开发
-
主题切换
-
夜间模式切换
-
字体切换
-
漂亮的骨架屏
-
利用
IDE
插件i18n
进行国际化 -
Dio结合Cookjar,实现
玩Android
的登录功能 -
AnimationList结合SmartRefresh的常规数据加载
-
当然还有WanAndroid本身也有不错的内容,每日闲暇时,可以读一读。
未完成的功能
-
首页二楼目前是我个人的blog,也无法前进后退。后期会放一个flutter专题。
-
Hero动画,在非最后一个tab登陆时,logo的动画会漂移到最后一个,需要加状态判断。
-
退出登陆加入动效。
目前已知存在的问题
-
webview_flutter 插件的问题还是很多,有些链接点击会没有反应,不会跳转。所以接入了两套WebView方案
-
webview_flutter 不能结合
CustomScrollView
滑动。见issue 。 -
两个同样颜色的widget,中间莫名其妙的会多一条背景色的线。见issue 。
Future
- 后期会上线大量博客,来讲述这个项目里所遇到的问题及解决的思路。
寻找组织
- Fun Flutter微信交流群
作者的话
- 坐标上海,打算找Flutter方向的工作.4年Android开发经验.
感谢
-
感谢 V2Lf 开源项目,很早就在TestFlight中下载了该App,那时还没开源。萌生了想做一个开源的App的想法。
-
借鉴了
goweii
WanAndroid项目的UI,最美原生版WanAndroid,感谢。 -
在实践Provider时,发现了Tutorials,作者Youtube的教程很好。
-
感谢优秀的pull_to_refresh刷新库。
-
感谢站酷提供的开源的字体。
写在最后
本次我的分享也接近尾声了,感谢你们在百忙中花上一下午来这里聆听我的宣讲,希望在接下来的日子,我们共同成长,一起进步!!!
最后放上一个大概的Android学习方向及思路(详细的内容太多了~),提供给大家:
对于程序员来说,要学习的知识内容、技术有太多太多,这里就先放上一部分,其他的内容有机会在后面的文章向大家呈现出来,不过我自己所有的学习资料都整理成了一个文档,一直在不断学习,希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
Android架构师之路很漫长,一起共勉吧!
如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
…(img-ajO8M3Fd-1715672292605)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!