Flutter初探 上下拉分页请求+计算器

本文主要大致介绍Flutter 整体框架,简单粗略的使用,深度暂且还没有。

用Dart,写了个计算器的demo和列表拉下刷新请求demo,基本上入门flutter使用,

源码可在文章后查看。

目录

  • 一、关于Flutter
  • 二、代码大致解读
  • 三、混合开发
  • 总结

一、关于Flutter

1、flutter介绍

Flutter是一个使用Dart语言开发的跨平台移动UI框架,通过自建绘制引擎,能高性能、高保真地进行Android和IOS开发,提供响应式视图而不需要JavaScript桥接器的移动SDK,这就是与和React Native不一样也是优势所在,采用Dart的程序语言来编译避免由JavaScript桥接器引起的性能问题,

开发语言:dart

  1. dart具有JIT&AOT双重编译执行方式。这样就能利用JIt进行开发阶段的hot reload开发,提升研发效率。同时在最终release版本中使用aot将dart代码直接变成目标平台的指令集代码。简单高效,最大限度保障了性能,最大限度减少包的大小,目前刚更新flutter preview2.0 对包的大小进一步缩减。
  2. dart针对flutter中频繁创建销毁Widget的场景做了专门的gc优化。通过分代无锁垃圾回收器,将gc对性能的影响降至最低。
  3. dart语言在语法上面是类java的,易学易用,对于我们原生开发而言 学习JS,Dart语言更能被接受。(个人感觉)

dart语言的优势详细介绍

Dart语言中文社区-基本语法等介绍

2、环境配置

中文配置教程

3、flutter特色--你可能会选它的几个理由

  1. 热加载: Flutter 最酷的功能之一,允许你像更新网页一样去实时的更新你的项目。
  2. 界面UI风格优美: UI 全是代码写的而不是 XML。(组件上)并且有丰富的 (Material Design |Cupertino) 组件,实现保持Android 和IOS风格展示一致的效果,Android也可以以IOS风格展示;(主题上) Android/iOS 的不同主题提供api直接判断不同类型,继而展示不同UI
  3. 组件足够小: Flutter 中的有个核心原则 — 组合优先于继承 他的每一个基础组件非常细微,所以可以自己组装创建各式各样的组件
  4. 后援很强大:第三方库不断新增中,Flutter开发社区真的很大,而且非常活跃,国内闲鱼已经上线一版,并作为flutter领导者,在前面不断踩坑中;

4、美中不足

  1. 与RN相比,在性能上和局限性上,可以胜之有余,但是对于在线热更新这个点,目前没有可行的预兆,除非把dart的编译AOT编译放在客户端中,显然是不现实的;虽然,苹果爸爸一直禁用app热更新代码的态度坚决而明确;这个不好评判了
  2. 代码上:括号太多了,各种嵌套,代码看起来非常不友好;但是了解其之用法之后,将整个页面分块区分成一个小模块独立,可读性我个人感觉还ok;
  3. 毕竟flutter紧跟RN之后才诞生,目前社区,开源方面相对于RN,还不够完善;

5、flutter--widget

上述图中可以看到:

Framework使用dart实现,包括Material Design风格的Widget,Cupertino(针对iOS)风格的Widgets,文本/图片/按钮等基础Widgets,渲染,动画,手势等。此部分的核心代码是:flutter仓库下的flutter package,以及sky_engine仓库下的io,async,ui(dart:ui库提供了Flutter框架和引擎之间的接口)等package。

Engine使用C++实现,主要包括:Skia,Dart和Text。Skia是开源的二维图形库;提供了适用于多种软硬件平台的通用API。Dart部分主要包括:Dart Runtime,Garbage Collection(GC);Text即文本渲染,其渲染层次如下:衍生自minikin的libtxt库(用于字体选择,分隔行)

虽然深入下去的 暂时还不懂,不难看出widget是我们所能涉及到开发的那一层。Flutter 的核心设计思想便是Everything’s a Widget 即一切即Widget。在flutter的世界里,包括views,view controllers,layouts等在内的概念都建立在Widget之上。widget是flutter功能的抽象描述。所以掌握Flutter的基础就是学会使用widget开始。

由widget展开的基础组件,布局,交互等;

二、代码大致解读

1、按照惯例 --- Hello World

@override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Welcome to Flutter',
      home: new Scaffold(
        appBar: new AppBar(
          title: new Text('Welcome to Flutter'),
        ),
        body: new Center(
          child: new Text('Hello World'),
        ),
      ),
    );
  }
} 

一个 layout 是由嵌套的组件(Widgets)构建的, 核心 Widget 是 MaterialApp (这是整个的应用程序), 然后我们有 Scaffold (这是我们主界面的 layout 结构),再然后是 AppBar (就像 Android Toolbar) 和 一些 Container 作为 body,在 body 内部,我们可以放置我们 layout 组件 — Texts, Buttons 等等。

2、布局

fef361039bdd30af7dd5a4cab38fbf8.png

1、 布局拆封:

这是一个简单的计算器页面,很明朗的将整个布局用Colunm竖向排列,Item中的Row再做横向布局,在Flutter 布局中,体现的是横向与竖向的概念 约束方面也是以此为基础 MainAxisAlignment主轴约束(水平X轴)

CrossAxisAlignment副轴约束(竖直Y轴)。在这里说明下,Flutter没有了原来Android的相对布局,但是用它已有的控件,能达到所有需要各种布局约束要求;

吐槽一点:刚学习这种布局方式,对于约束方法不熟悉,布局很头疼,就像按照格子线去排放不同物品,一点一点挪动,好在热重载,改一行代码就能看见效果

​ 收藏一波各类约束布局的控件:SizedOverflowBox,OverflowBox,LimitedBox,FractionallySizedBox,SizedBox & ConstrainedBox,FittedBox,RotatedBox等等;有些控件比较冷门需要自己去慢慢收藏,没用过基本不知道有这样的都已经帮你写好的,能提高不少效率 ;

[按钮控件扩展](https://zhuanlan.zhihu.com/p/38500192�" >,)

2、State生命周期:

​ flutter和RN一致,采用响应式视图,维护了一个状态机,只更新改变的最小区域界面 ;
​ 它有两类widght:

StatelessWidget(无状态):UI纯展示作用,无交互以及UI变化,例如:提示语等;

StatefulWidget(有状态):程序运行中,UI发生变化的,以及用户交互的;

State的生命周期有四种状态:

  • created:当State对象被创建时候,State.initState方法会被调用;
  • initialized:当State对象被创建,但还没有准备构建时,State.didChangeDependencies在这个时候会被调用;
  • ready:State对象已经准备好了构建,State.dispose没有被调用的时候;
  • defunct:State.dispose被调用后,State对象不能够被构建。

调用setState方法后,更新视图,数据改变或者UI需要发生变化,需要再setState方法里对数据源进行更新,然后布局会用新的数据源重新build,

3、异步-- 网络请求

常用的async await Future搭配

//HTTP的get请求返回值为Future<String>类型,即其返回值未来是一个String类型的值
getData() async {    //async关键字声明该函数内部有代码需要延迟执行
  return await http.get(URL); //await关键字声明运算为延迟执行,然后return运算结果
}

这时候 如果直接执行 :

  String data = getData();

就直接会报错

因为dataString类型,而函数getData()是一个异步操作函数,其返回值是一个await延迟执行的结果。在Dart中,有await标记的运算,其结果值都是一个Future对象,Future不是String类型,所以就报错了

可以这么实现:

getData().then(data){
   String _data = data;
}

FuturethenAPI,作用为getData()异步执行完成后,在调用then方法,并且与Future 后面的语句先顺序执行

三、混合开发

针对我们目前公版上或者分支上的项目而言,不可能将整个项目移植成Flutter,显然是不现实的。如若是一个新的小项目,我觉得认为这个是可以是个新的尝试,新的技术氛围,也可以衍生或者接触其他的更多领域,有利于增加团队氛围。

当然还有一个尝试:像之前RN一样,独立一些模块功能使用flutter开发,将这些独立模块使用类似SDK形式,引入我们的项目中,开放出接口给Native调用;

问题:由Flutter目录再分别包含Native工程的目录(即ios和android两个目录)组成。默认情况下,引入了Flutter的Native工程无法脱离父目录进行独立构建和运行,因为它会反向依赖于Flutter相关的库和资源

闲鱼针对项目混合开发改造实践

总结

Dart语言,运用起来,函数思想与kotlin类似,Dart语言上的特性,kotlin都有,唯一算的上特点就是Dart编译速度快了。面对对象的思想,和java如出一辙,我学起来倒也不是很吃力。对于编写代码来讲,槽点就是他的代码风格,括号嵌套太多,每个组件后,以“,”结尾,这样格式化稍微好一些;

Flutter官方吹的很大,说它是革命性的,也有一定道理。但是我觉得RN对于熟悉web开发的人来说,是更好的选择。但是对于纯native开发的移动开发人员,直接学习Flutter会更好,Flutter也比较适合本来就是做native开发的人
目前,Flutter还是处于beta版本,尽管如此,现在闲鱼也已经作为大头,在前面领路了。作为Google亲儿子,相信Flutter 不会像RN一样,路途那么坎坷

官方资源

1、Flutter官网

2、Flutter快速入门

3、Flutter—API 文档

4、Githu


b

5、Google+网上论坛

6、Twitter

7、Gitter

8、Flutter技术周报

项目demo:flutter_demo:下拉请求刷新|计算器

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