若是你还在犹豫为何要学Flutter,下面2个图的应该足够吸引你加入了吧,一套代码多平台使用
Flutter 是 Google 用以帮助开发者在 iOS 和 Android 两个平台开发高质量原生应用的全新移动 UI 框架。
Flutter又是谷歌钦定的下一代移动操做系统Fuchsia的UI框架。 做为一名Android Developer,看到是Google出的,且还能开发iOS,仍是有必要学习下的!前端
最近经过学习Flutter,认识不少人,特别是后端的各类大佬也在疯狂学习,做为移动端的咱们亚历山大!!!git
本文主要讲了我本身的一个学习过程以及使用感觉,但愿对正在学习Flutter的朋友有必定帮助,对想要入坑Flutter的朋友进行一些相关介绍github
主要学习资料
- Flutter官网
- Flutter中文
- 在线Dart学习
- Tensor Programming
- DartConf 2018系列
- 闲鱼技术
代码练习
- 选择一个整片的时间进行学习编码。
- 尝试解决别人在群里或者私信中提出的问题,后来学习的人愈来愈多,这一块也成了我主要的代码练习块。
- 从Github中的项目学习,主要是学习一些Flutter的编码格式以及项目结构(以前被人吐槽过编码格式不合理,查证后把不合理的代码格式从新写了一次)
学习代码已整理成Demo上传到Github, 每个知识点都有一个独立的例子供参考:
1.基础布局
2.数据请求
3.MVP实现
4.上拉加载(监测到最底端直接刷新,待优化),下拉刷新
5.主题学习
6.路由
7.drawer
8.数据存储三种方式(文件,SharedPreference,sqflite)
9.手势
10.图片加载
11.生命周期
12.网络请求(dio,http,原生)
13.多点触控
14.InheritedWidget
15.TabBarView & TabBar ,切换的时候,每次都会执行initState。
16.GlobalKey(简单使用)
17.国际化
18.Notification自下而上传递数据
19.显示/隐藏widget
20.drag
21.Animation
22.StreamController
23.Business Logic Component
24.Simple Redux & Simple BLoC
App实践
学了那么多基础的知识,确定要本身尝试写一个App,将知识点整合到一块儿使用。后端
完成
1.今日热点
2.主题分类
3.文章详情
4.抽屉列表增长缓存, 防止屡次拉去数据
5.评论列表
6.主题列表
7.主页banner自动轮播,手指滑动是禁止轮播,放开则继续
8.刷新数据失败,增长重试按钮
9.分享UI,登陆UI,联动交互缓存
待优化
1.Flutter加载Html服务器
因为Api有限没法完成跟用户相关的操做
1.注册
2.登陆
3.发表评论
4.收藏网络
学习&使用的感觉
- 须要学习一门新的语言Dart,对于有移动端和前端开发基础的人来讲,不算很困难。
- 开发过程当中Hot Reload大大的提升开发效率。
- 树型布局,须要转变本身的布局思惟,一切都是widget,这个概念在在Flutter特别重要,由于在使用的过程当中你须要展示给用户的UI都是依靠各类类型的组件,经过组合的方式生成。
- 对于你们认为树型布局的嵌套层次较深,看起来极为不直观的问题,只须要将一个复杂的布局进行拆解,作成独立的widget,而后再进行组装,这样不只解决了阅读代码不直观的问题,并且也大大提升了widget的复用性。
- 对于网络请求的数据这一块,若是服务器返回的数据嵌套层次较多,会让开发者会较多的时间去整理,封装,写解析体。
- 本身自己是作开发Android的,因此习惯的使用了MVP的模式,实践项目写完之后感受有点笨重,可能须要摒弃一些移动端老的编码观念,在后续接触到国外的一些开源项目,使用了的BLoC或者Redux,做为响应式框架,我的感受这两种架构比MVP更适合Flutter的开发。
- 开发的时候咱们在debug模式下会稍显卡顿,后续作了个release包,分别在iOS和Android的真机上运行,从用户体验的角度去看,性能上几乎和原生没差异,是能够接受的。
- 实践的项目分别打release包,iOS版有16.16M,Android版有8.02M,相对原生较大。
- 成熟轮子较少,官方或者大厂维护的插件很少,例如第三方平台登录,支付,分享,国内地图等,咱们须要本身作插件,这个就迫使咱们目前须要掌握2种平台的开发iOS和Android,这个学习成本就相对高一点。
从 0 到 1:个人 Flutter 技术实践 | 掘金技术征文,征文活动正在进行中架构