专栏首页吴小龙同學Flutter 初尝:从 Java 无缝过渡

Flutter 初尝:从 Java 无缝过渡

准备阶段

下载 Flutter SDK

如果不能访问外国网站,可以声明 PUB_HOSTED_URL 和 FLUTTER_STORAGE_BASE_URL 两个环境变量,执行如下两行命令,是为了让 Flutter 在安装过程中使用国内的镜像:

12

export PUB_HOSTED_URL=https://pub.flutter-io.cnexport FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn

新建 Flutter 文件夹,克隆 Flutter SDK:

1

git clone -b beta https://github.com/flutter/flutter.git

配置 Flutter 环境

我是 Mac 系统,Flutter SDK 下载完后的路径:Users/wuxiaolong/Flutter/flutter/ 。

在命令行下,进入用户目录

1

cd $HOME

打开.bash_profile文件

执行命令打开文件:

1

open -e .bash_profile

打开文件后,添加 Flutter SDK 安装的路径:

12

export PATH=${PATH}:/Users/wuxiaolong/Flutter/flutter/bin:$PATH`

更新刚配置的环境变量

1

source .bash_profile

验证

终端直接输入 flutter,没有提示该命令找不到,则配置成功。

flutter doctor

命令行输入flutter doctor,安装 Futter 剩余依赖项。

安装 Flutter 和 Dart 插件

启动 Android Studio,搜索 Flutter 插件并单击 install,系统提示您安装 Dart 插件,点击 Yes 安装即可。

提示:安装 Dart 插件可能会提示下载失败,多试几次。

第一个项目

Android Studio - File - New - New Flutter Project,等待创建成功后,运行效果如下:

Dart 基本语法

Flutter 开发语言是 Dart,这个语言相信我们做原生 Android 的都能看懂,我在学习过程,感觉这不就是 Java 嘛,我直接按照 Java 思维去写,完全没问题。

  1. 基础数据类型有 int、double、bool、String、List(数组)、Map;
  2. 声明变量可以使用 var,也可以使用 const 和 final;
  3. const 和 final 定义的都是常量,值不能改变,并且在声明的时候就必须初始化,这是可以省略 var 或者其他类型;
  4. 函数可以有可选参数;
  5. if-else、for 循环、while 循环、switch-case、try-catch 等知识与 Java 类似;

更多详见官网:https://www.dartlang.org/

练手

这里使用了豆瓣电影的 API,功能很简单,就一个列表和详情。

效果预览

遇到问题

学习新知识,第一步就是模仿,多看,多想,多实践,在这个过程我遇到一些问题:

  1. Flutter 怎么打印信息?print('onclick');
  2. Flutter 如何看报错信息?在 Android Studio 底栏 Run 非 LogCat;
  3. 网络请求怎么写?
  4. 接口数据如何解析的?
  5. 如何一进页面就请求接口?
  6. 网络图片怎么显示?
  7. ListView 官网介绍的 Item 是通用的,如何定制?
  8. 跳转页面如何传参?传参后怎么用?

等等,遇到一个问题,消灭一个。

源码

源码地址

https://github.com/WuXiaolong/flutter_movie ,该项目起始页面在 lib/main.dart,注意的点我也都加了注释,去吧,学习还是要靠自己,踏出第一步,实践起来。

如何导入 Flutter 项目

下载 Flutter 项目

下载完 Flutter 项目,直接 Android Studio - Open。

配置 Flutter SDK

如图,点击 Open Flutter setting,点击下拉按钮,选择 Flutter SDK 路径,点击 OK,会自动配置 Dart SDK 路径。

pubspec.yaml 下载库

如图,点击 Packages get,下载项目用到的依赖库,编译完成应该就能正常运行了。

最后

  1. 还是被 Flutter 惊艳到了,重拾当初学习 Android 的热情,却一不小心,我的肩痛又开始了;
  2. Flutter UI 全是代码写的,不是 XML,复杂的 UI 实现有难度;
  3. Flutter 联想功能较弱,需要先导入相应的包,才有相应的类联想;
  4. 新建了一个 package,将 dart 文件拖入,相关联包的路径会相应修改,但是我改了package 名,就无法相应修改,bug?
  5. Flutter,我感觉可以从 Java 实现无缝过度;
  6. I’m a iOS Developer.
  7. Flutter 开源库远没有原生的丰富,目前还是 Beta 版,还是很值得期待,我会持续关注学习,先就酱紫吧。

相关阅读

Flutter 官网

Mac 配置 adb 环境、gradlew:command not found

FlutterMates

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Android 系统开发做什么?

    18 年我从 Android 应用开发转 Framework 层开发了,从此开启了 996 幸福生活,博客技术文更新基本停滞了,被工作占据了过多的精力,实在没时...

    吴小龙同學
  • Android Studio 导入 AOSP 源码

    有了 AOSP 源码,接下来就是如何看了,可以直接文本看,可以用 Source Insight,我当然选择 Android Studio,Android Stu...

    吴小龙同學
  • Android 当点击飞行模式都发生了什么?

    今天中午午休时,我把手机开飞行模式了,能看到 WiFi 、蜂窝数据和蓝牙都关闭了,心想,这时候还能收到短信吗?顺着好奇心,我们不妨来研究一下源码,看看点击飞行模...

    吴小龙同學
  • Flutter 核心原理与混合开发模式

    在 「Fan 直播」的 Flutter 混合开发实践中,我们总结了一些 Flutter 混合开发的经验。本文第一篇章将从 Flutter 原理出发,详细介绍 ...

    QQ音乐技术团队
  • Flutter2 来了!!!

    今天,我们宣布Flutter 2:Flutter的重大升级,使开发人员能够为任何平台创建美观,快速且可移植的应用程序。借助Flutter 2,您可以使用相同的代...

    ZY_FlyWay
  • 2021年如何学习Flutter?

    Flutter之所以变得流行,是因为它具有快速构建应用程序的灵活性以及易于学习语言的灵活性。不管您是经验丰富的开发人员还是新手,观看一些有用的视频,收集一些在线...

    蓝默空间
  • Flutter-初试牛刀,入门篇

    好像说的就是我呀。学习Flutter一段时间了,我感觉我要入门了,特来总结一下遇到的点点滴滴。如下效果就是我用Flutter重写的曾经项目部分效果,说是部分其实...

    Light413
  • 革命性移动端开发框架-Flutter时间简史

    说到Flutter,可能很多同学都会将它和这几个词关联起来:新兴的、移动端、动态化、跨平台、开发框架。

    猿哥
  • 程序猿Skr ----- Flutter之歌

    版权声明:本文为博主原创文章,本文首发在公众号 Flutter那些事,版权归作者 AWeiLoveAndroid 所有,未经博主允许不得转载。https://w...

    AWeiLoveAndroid
  • Flutter 2 正式出道(一)

    相信不少人昨晚熬夜奋战,观看了Flutter Engage大会,Flutter团队也正式官宣了Flutter 2。从Flutter 1.0正式版到Flutter...

    JarvanMo

扫码关注云+社区

领取腾讯云代金券

,,