准备阶段

下载 Flutter SDK

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

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

配置 Flutter 环境

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

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

cd $HOME

打开.bash_profile文件

执行命令打开文件:

open -e .bash_profile

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

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

更新刚配置的环境变量

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

公众号

我的公众号:吴小龙同学,欢迎交流~

Flutter 初尝:从 Java 无缝过渡的更多相关文章

  1. .NET领域驱动设计—初尝(三:穿过迷雾走向光明)

    开篇介绍 在开始这篇富有某种奇妙感觉的文章之旅时我们先短暂的讨论一下关于软件开发方法论的简要: 纵观软件开发方法论,从瀑布模型.螺旋模型.RUP(统一软件开发过程).XP(极限编程).Agile(敏捷 ...

  2. 分布式设计《初尝memcached》

          之前听说过高性能的分布式缓存开源工具,但一直没有真正接触过,如今接触的产品中实用到过分布式缓存.所以决定一探到底.memcached是一个优秀的开源的分布式缓存工具.也是眼下比較火热的分布 ...

  3. 初尝Windows 下批处理编程

    本文叫“ 初尝Windows 下批处理编程”是为了延续上一篇“初尝 Perl”,其实对于博主而言批处理以及批处理编程早就接触过了. 本文包括以下内容 1.什么是批处理 2.常用批处理命令 3.简介批处 ...

  4. 初尝 Perl

    本文将阐述以下几方面内容: 1.什么是Perl 2.Perl有什么用 3.Windows 下的Perl环境搭建 4.Perl 版Hello World 5.Perl 语法梗概 6.一些参考资料 什么是 ...

  5. seajs初尝 加载jquery返回null解决学习日志含示例下载

    原文地址:http://www.tuicool.com/articles/bmuaEb 如需demo示例,请点击下方链接下载: http://yunpan.cn/cVEybKs8nV7CF  提取码 ...

  6. flutter初体验

    flutter初体验 和flutter斗争了两个周末,基本弄清楚了这个玩意的布局和一些常用组件了. 在flutter里面,所有东西都是组件Widget.我们像拼接积木一样拼接Widget,拼接的关键词 ...

  7. 初尝微信小程序2-Swiper组件、导航栏标题配置

    swiper 滑块视图容器. 很多网页的首页都会有一个滚动的图片模块,比如天猫超市首页,滚动着很多优惠活动的图片,用来介绍优惠内容,以及供用户点击快速跳转到相应页面. Swiper不仅可以滚动图片,也 ...

  8. .NET领域驱动设计—初尝(一:疑问、模式、原则、工具、过程、框架、实践)

     .NET领域驱动设计—初尝(一:疑问.模式.原则.工具.过程.框架.实践) 2013-04-07 17:35:27 标签:.NET DDD 驱动设计 原创作品,允许转载,转载时请务必以超链接形式标明 ...

  9. Github原生CI/CD,初尝Github Actions

    Github 原生 CI/CD,初尝 Github Actions Intro Github 目前已经推出了自己的 CICD 服务 -- Github Actions,而且比微软的 Azure Dev ...

随机推荐

  1. BZOJ 3238: [Ahoi2013]差异 [后缀自动机]

    3238: [Ahoi2013]差异 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2512  Solved: 1140[Submit][Status ...

  2. ES6,Array.includes()函数的用法

    在ES5,Array已经提供了indexOf用来查找某个元素的位置,如果不存在就返回-1,但是这个函数在判断数组是否包含某个元素时有两个小不足,第一个是它会返回-1和元素的位置来表示是否包含,在定位方 ...

  3. phpstudy 版本切换注意的问题

    如果你也在使用phpstudy的话要注意,因为切换版本后,虽然你的phpinfo 但是实际环境用的是系统环境变量 所以你要去改变下环境变量路径,然后重启电脑. 这样你的版本就是你想切换的版本啦!

  4. go 开发环境安装教程 windows

         首先进入go 语言官网下载最新安装包,我目前安装的版本是 1.8.3版本:go1.8.3.windows-amd64.msi 如果下载慢,这个是百度云地址:https://pan.baidu ...

  5. Zabbix 3.2.4至3.2.7的升级方案

    1.关闭Zabbix Server 防止有新的数据提交到数据库中,也可以关闭数据库.如果更新过程中,评估告警信息可以忽略,可以先执行备份操作. 1.1.检查当前版本 /usr/local/zabbix ...

  6. 利用Azure嵌套虚拟化,解决公有云上机器不能启动的问题

    很多时候我们都会碰到因为意外重启,机器硬盘被损坏导致无法启动,或者是因为各种原因Windows上的RDP服务启动不了,Linux上的SSH无法链接等等问题.碰到这种问题基本上很难解决以前都是将VHD下 ...

  7. hibhibernate中hql中的语句where语句查询List出现空

    1.java.sql.Date 与 java.util.Date java.sql.Date是从java.util.Date中继承而来 假设 dates1(java.sql.Date)要赋值给date ...

  8. LNMP搭建环境遇到的N多坑

    最近配置开发用的lnmp环境,环境配置完成后,爆500错误,查看nginx错误日志 open_basedir 将 PHP 所能打开的文件限制在指定的目录树,包括文件本身 错误日志显示,访问脚本不在 o ...

  9. ul 和 ol 标签的相关设置

    初学者不喜欢 ul 标签的最重要一点莫过于其前面的黑点了,每次写个无序列表其前面总有一个黑点是个很讨厌的事,去掉黑点的话自然是要用到 list-style:none:这条css 属性设置了. p.p1 ...

  10. windows下用pip安装软件超时解决方案

    以前介绍过ubuntu下更换更新源办法,详情见http://www.cnblogs.com/Alier/p/6358447.html 下面讲一下windows下面pip的配置更改,包括下载软件是超时错 ...