前言

工欲善其事,必先利其器

所以第一篇我们来说说 Flutter 环境的搭建。

笔者这边使用的是 MAC 电脑,因此以 MAC 电脑的环境搭建为例。

Windows 或者 Linux 也是类似的操作。

Flutter 有英文版的官网和中文网,大家可以根据自己的喜好和情况进行选择。

点击下面的链接可以到对应的安装页面。

Flutter 官网安装链接

Flutter 中文网安装链接

我们这边以官网为例进行说明。

目录

1. 配置镜像

点击进入官网,可以看到下图:

我们点击 Using Flutter in China 进入:

可以看到主要是让我们配置镜像站点。

所以我们就将要求的两个环境变量添加到系统就可以了。

打开 terminal,看下当前用户下面是否有 bash_profile 文件,执行命令:

vi ~/.bash_profile

如果底部有

"~/.bash_profile" [New File]

说明之前没有存在过这个文件。

不管之前是否存在过该文件,我们在末尾追加上面的两个环境变量即可。

如果不熟悉 vi 操作,可以参考下面两篇文章或者额外了解。

linux Vi操作和使用方法详解

Linux vi/vim

将上面两个环境变量添加到 bash_profile 文件,文件新增的两行应该类似下面(镜像地址可能有变动,以上面官网为主,笔者此刻就是下面的):

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

接着执行命令:

source ~/.bash_profile
echo $PUB_HOSTED_URL

如果打印出了你输入的镜像,说明没有问题,设置成功了。

主要目的是追加两个环境变量,如果你习惯用文件打开,也可以打开文件后直接追加

回到安装页面,点击 macOS。

2. 获取 Flutter SDK

从图中可以看到,当前的目标是获取 Flutter SDK。

点击蓝色按钮,下载 Flutter SDK。

下载完成之后解压到自己想放置的目录(建议路径不要包含中文)。

这里假设我们将压缩包解压到的路径为 ~/flutter。

首先把下载下来的压缩包移动到 ~/flutter。

我这边下载的压缩包为flutter_macos_v1.0.0-stable.zip,执行命令

unzip flutter_macos_v1.0.0-stable.zip

执行完成之后可以看到当前目录多了一个 flutter 文件夹。

接下来就是要把 flutter 设置到环境变量以便在任何地方都可以执行 flutter 命令。

执行如下命令:

cd flutter/
pwd

控制窗口会打印 flutter 根目录。我这边为/Users/nesger/flutter/flutter。

跟上面设置两个环境变量操作类似,首先打开文件~/.bash_profile。

添加下面语句:

export FLUTTER_ROOT=/Users/nesger/flutter/flutter
export PATH=$FLUTTER_ROOT/bin:$PATH

这里定义了 flutter 根目录并将其下面的 bin 目录设置到 PATH 里面。

保存退出后执行

source ~/.bash_profile

NOTE:执行该命令后你当前窗口和新开的窗口就都可以直接运行 flutter 命令了。但是之前开的窗口就不可以了。如果需要之前的窗口也可以,就需要在对应窗口执行上面的 source ~/.bash_profile 命令

3. 执行 flutter doctor 完善相关工具链

运行

flutter doctor

会打印 flutter 需要的工具链是否完善。(NOTE: 这个命令后面会多次用到)

可以看出一些端倪。

显示一些警告。

按照上面提示进行处理即可。

举个例子:

✗ Android licenses not accepted.  To resolve this, run: flutter doctor --android-licenses

这边说 Android licenses 没有 accepted,执行

flutter doctor --android-licenses

然后不断点击 y 表示同意就可以了。

我们运行之后,再使用

flutter doctor

可以看到已经修复了

接下来就是 iOS toolchain 以及 Android Studio 两个插件的安装。

对于 Android 开发来说,其实 iOS toolchain 不修复也没问题。

我们先修复 flutter 插件安装。

NOTE:Android Studio 版本需要 3.0 或者更高版本,不然会有坑,这边为了演示一下坑及遇到的解决方法。所以这边先用版本 2.3.3 进行演示。读者最好先升级版本到 3.0。步骤是一样的。

第一步:Android Studio->Preferences



第二步:点击左侧 Plugins



第三步:输入 flutter,点击 Search in repositories



第四步:点击 Install



第五步:dart 一起安装

安装完成之后重启 Android Studio,然后在终端执行命令

flutter doctor

可以看到 Flutter 插件安装好了,只不过这里提示版本不够新。

如果你的 Android Studio 版本为 3.0 或者更高,就不会报错,那么可以忽略下面的修复步骤。

修复步骤:

重启 Android Studio 并没有看到直接创建 Flutter 项目。

笔者这边 Android Studio 版本为 2.3.3。

而 Flutter 需要 Android Studio 3.0 或者更高版本支持。

这边更新 Android Studio 之后重启。

可以看到执行 flutter doctor 命令之后 Android Studio 确实是 3.3 版本了。

但是 Flutter 依然不是最新的,需要到 plugins 去更新。

此外,还需要更新 dart。

更新完之后就可以看到创建 Flutter 项目了。

到了这里基本上对于 Android 开发的你来说环境搭建就完成了。

4. 扩展

可以看到上面有个 iOS toolchain,基于下面几点,我想修复这个。

  1. 我的机器安装了 Xcode。
  2. 刚接触 Flutter,想多点尝试,也想看看 Flutter 代码在 iOS 运行效果。
  3. 听说 iOS 开发都用模拟器,想体验下 iOS 模拟器。

    Android 的模拟器大家都懂,反正我大部分是用真机调试。

所以按照上面的提示,Xcode 完全安装以及运行相应命令。

但是遇到了一个坑,就是依然报错。

所以我直接将提示的命令一步执行,结果可以了。

在 GitHub 上面还帮助到了一个 iOS 开发者。

flutter doctor 提示 iOS toolchain 有些错误

更多环境搭建问题和解决方案大家都可以提 issue 哦~

也许别人刚好就解决了你遇到的问题

Flutter Issue 集合

Flutter 即学即用系列博客——01 环境搭建的更多相关文章

  1. Flutter 即学即用系列博客——05 StatelessWidget vs StatefulWidget

    前言 上一篇我们对 Flutter UI 有了一个基本的了解. 这一篇我们通过自定义 Widget 来了解下如何写一个 Widget? 然而 Widget 有两个,StatelessWidget 和 ...

  2. Flutter 即学即用系列博客——04 Flutter UI 初窥

    前面三篇可以算是一个小小的里程碑. 主要是介绍了 Flutter 环境的搭建.如何创建 Flutter 项目以及如何在旧有 Android 项目引入 Flutter. 这一篇我们来学习下 Flutte ...

  3. Flutter 即学即用系列博客——09 EventChannel 实现原生与 Flutter 通信(一)

    前言 紧接着上一篇,这一篇我们讲一下原生怎么给 Flutter 发信号,即原生-> Flutter 还是通过 Flutter 官网的 Example 来讲解. 案例 接着上一次,这一次我们让原生 ...

  4. Flutter 即学即用系列博客——08 MethodChannel 实现 Flutter 与原生通信

    背景 前面我们讲了很多 Flutter 相关的知识点,但是我们并没有介绍怎样实现 Flutter 与原生的通信. 比如我在 Flutter UI 上面点击了一个按钮,我希望原生做一些处理,那么原生怎么 ...

  5. Flutter 即学即用系列博客——06 超实用 Widget 集锦

    本篇文章我们来讲讲一些比较常用的 Widget. 大家验证的时候使用下面的代码替换 main.dart 代码,然后在 //TODO 语句返回下面常用 Widget 示例的代码. import 'pac ...

  6. Flutter 即学即用系列博客——03 在旧有项目引入 Flutter

    前言 其实如果打算在实际项目中引入 Flutter,完全将旧有项目改造成纯 Flutter 项目的可能性比较小,更多的是在旧有项目引入 Flutter. 因此本篇我们就说一说如何在旧有项目引入 Flu ...

  7. Flutter 即学即用系列博客总结篇

    前言 迟到的总结篇,其实大家看我之前发的系列博客最后一篇,发文时间是 3 月 29 日.距离现在快两个月了. 主要是因为有很多事情在忙,所以这篇就耽搁了. 今天终于可以跟大家会面了. 系列博客背景 F ...

  8. Flutter 即学即用系列博客——09 MethodChannel 实现原生与 Flutter 通信(二)

    前言 上一篇我们讲解了如何通过 EventChannel 实现 Android -> Flutter 的通信. 并且也看到了 Flutter 内部 EventChannel 源码也是对 Meth ...

  9. Flutter 即学即用系列博客——02 一个纯 Flutter Demo 说明

    前言 上一篇文章我们搭建好了 Flutter 的开发环境. Flutter 即学即用--01 环境搭建 这一篇我们通过 Flutter 的一个 Demo 来了解下 Flutter. 开发系统:MAC ...

随机推荐

  1. 【转】Fundebug上线微信小游戏错误监控!支持自动截屏!

    摘要: Fundebug竭诚为你的小游戏保驾护航. 想必大家都玩过"跳一跳"吧?刷排行榜的感觉是不是很好啊!还有"知乎答题王"呢,在智力上碾压老铁简直太棒了! ...

  2. Unity3D学习(四):小游戏Konster的整体代码重构

    前言 翻了下之前写的代码,画了个图看了下代码结构,感觉太烂了,有很多地方的代码重复啰嗦,耦合也紧,开个随笔记录下重构的过程. 过程 _____2017.10.13_____ 结构图: 目前发现的待改进 ...

  3. PAT1081:Rational Sum

    1081. Rational Sum (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given N ...

  4. namespace------------https://www.cnblogs.com/linhaifeng/p/6657119.html

    PHP支持两种抽象的访问当前命名空间内部元素的方法,__NAMESPACE__ 魔术常量和namespace关键字. 常量__NAMESPACE__的值是包含当前命名空间名称的字符串.在全局的,不包括 ...

  5. posix,perl正则表达式区别

    1.正则表达式(Regular Expression,缩写为regexp,regex或regxp),又称正规表达式.正规表示式或常规表达式或正规化表示法或正规表示法,是指一个用来描述或者匹配一系列符合 ...

  6. 了解mysqlpump工具

    Ⅰ.功能分析 1.1 多线程介绍 mysqlpump是MySQL5.7的官方工具,用于取代mysqldump,其参数与mysqldump基本一样 mysqlpump是多线程备份,但只能到表级别,单表备 ...

  7. 阿里云和腾讯云免费SSL证书 专题

    阿里云部署SSL证书 http://www.cnblogs.com/sslwork/p/5984167.html 查找中间证书 为了确保兼容到所有浏览器,我们必须在阿里云上部署中间证书,如果不部署证书 ...

  8. salesforce lightning零基础学习(四) 事件(component events)简单介绍

    lightning component基于事件驱动模型来处理用户界面的交互.这种事件驱动模型和js的事件驱动模型也很相似,可以简单的理解成四部分: 1.事件源:产生事件的地方,可以是页面中的输入框,按 ...

  9. 2个byte类型数据相加(转型问题的分析)

    转自https://blog.csdn.net/alinshen/article/details/53571857 今天看到网上有网友问到关于final修饰的面试题目,题目如下: <span s ...

  10. java某些基础知识点整理

    1. \n换行 \r回车 \"双引号 \\反斜杠 2.Java语言提供了八种基本类型.六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型. byte: byte 数据类型是 ...