前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >学习Flutter之前,你先要了解这些

学习Flutter之前,你先要了解这些

作者头像
用户2802329
发布2018-12-18 16:15:04
1.9K0
发布2018-12-18 16:15:04
举报
文章被收录于专栏:Android先生

序言

Flutter 出来已经有些日子了,越来越多的开发者也开始尝试使用 Flutter 进行开发,Flutter 是谷歌的移动UI框架,基于 Dart 语言,支持多端开发(Android、iOS、Web),听到这里是不是想要跃跃欲试了,由于LZ也正在踩坑的路上,所以有写的不对的地方还请多多指教。

官网

任何一门语言,官网都是最好的学习渠道,虽然说大多数都是英文的,但现在谷歌已经有很多都支持中文版本了:

Flutter中文官网:https://flutterchina.club/

安装

安装直接按照官网的来就行了,最主要的就是配置一下环境变量,下载下来的 flutter 包你可以理解为 java 中的 jar 包,开发的时候需要导入的。

特性

1、widget(相当于Android中的View)

我们都知道,在 Android 中页面是由很多个View来构成的,在 Flutter 中,Widget 用来构成页面上的内容,但是和 View 不同的是,Widget 是不可变的,有些人可能就有疑问了,不可变那岂不是静态页面,非也非也,那肯定有其他办法的咯,接着往下看:

1.1、不可变状态的小部件StatelessWidget

你可以将 StatelessWidget 理解成 Android 中的 ViewGroup,这是一个无状态的小部件,什么意思呢,就是当你的页面部分不依赖于对象配置信息外的其他任何内容时,简而言之就是你的页面是静态页面时,就可以使用它。

1.2、可变状态的小部件StatefulWidget

和 StatelessWidget 一样可以理解为 ViewGroup,但是它是有状态的,这个状态类似于 Activity 的生命周期,当你的页面需要动态的改变时,你就需要使用它。

注意

如果一个 Widget 发生了变化(用户与之交互),那么它就是有状态的;如果一个子 Widget 是有状态的,那么包裹它的父 Widget 可以是有状态的也可以是无状态的,简而言之,StatelessWidget 中可以包含 StatefulWidget,而 StatefulWidget 中也可以包含 StatelessWidget。

2、Android中的四大组件还有与之对应的吗

除了页面之外,其他的肯定都没有,因为毕竟是跨端开发的框架,不是专门为 Android 而设计的,可能有些人要问了,那如果想实现 Android 中的一些特殊的功能岂不是做不了了,非也非也,这个就属于另外一个知识了,卖个关子先,接着往下看;Activity 和 Fragment 在 Flutter 中都变成了 Widget。

3、资源文件

3.1、资源图片

在Android中资源图片有很多种分辨率,Flutter 遵循像iOS这样简单的3种分辨率格式: 1x, 2x, and 3x,在根目录下创建一个 images 的文件夹,然后再在 images 文件夹中创建三个文件夹用来存放不同分辨率的图片:

  • ../icon.png
  • ../2.0x/icon.png
  • ../3.0x/icon.png

然后,你需要在 pubspec.yaml 中配置这些图片,这个文件相当于Android中的 gradle文件。

3.2、字符串

在 Flutter 中,目前最好的做法就是新建一个类,用来声明你所需要的字符串

代码语言:javascript
复制
1声明:
2class Strings{
3  static String welcomeMessage = "Welcome To Flutter";
4}
5
6使用:
7new Text(Strings.welcomeMessage);
4、生命周期

在 Flutter 中,StatelessWidget 是没有生命周期的,只有 StatefulWidget 才有,我们一般通过挂接到WidgetsBinding观察并监听didChangeAppLifecycleState更改事件来监听生命周期事件,有以下这些生命周期:

  • resumed - 应用程序可见并响应用户输入。这是来自Android的onResume
  • inactive - 应用程序处于非活动状态,并且未接收用户输入。此事件在Android上未使用,仅适用于iOS
  • paused - 应用程序当前对用户不可见,不响应用户输入,并在后台运行。这是来自Android的onPause
  • suspending - 该应用程序将暂时中止。这在iOS上未使用
5、异步UI

Dart是单线程执行模型,支持Isolates(在另一个线程上运行Dart代码的方式)、事件循环和异步编程。 除非您启动一个Isolate,否则您的Dart代码将在主UI线程中运行,并由事件循环驱动。

当你进行网络请求时,可以在UI线程直接运行网络请求代码:

代码语言:javascript
复制
1loadData() async {
2  String dataURL = "https://jsonplaceholder.typicode.com/posts";
3  http.Response response = await http.get(dataURL);
4  setState(() {
5    widgets = JSON.decode(response.body);
6  });
7}

这里使用了 async/await 语法来调用API,你可以理解为,使用 async 之后这个方法就变成了异步的方法,然后需要等待(await)网络请求完成之后再执行下面更新语句;在 StatefulWidget 中,我们使用 setState 方法来更新UI操作,这会重新执行 build 方法。

6、组件

在 Flutter 中,有很多组件,他们可以构建成页面,因为组件繁多,所以这里我就不一一介绍了,我会在接下来的博客中为大家一一介绍 Flutter 中各种组件的使用方法,也欢迎大家持续关注后续博客。

  • 6.1、Flutter组件学习(一)—— Text组件: https://www.jianshu.com/p/b8cd2064efd7

最后

提醒一下大家,如果开发过程中有大的修改时,还是不要相信 Flutter 的热重载,在看到运行情况与实际不符时,卸载重装再来一遍。最后的最后,上一张LZ花了一天半时间入门的Demo:

Flutter解析Demo:https://github.com/24Kshign/FlutterWorkSpace/tree/master/flutter_app_test

i

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-11-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 IT先森养成记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 序言
  • 官网
  • 安装
  • 特性
    • 1、widget(相当于Android中的View)
      • 2、Android中的四大组件还有与之对应的吗
        • 3、资源文件
          • 4、生命周期
            • 5、异步UI
              • 6、组件
              • 最后
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档