Flutter - 极速构建漂亮的原生应用

Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面。 Flutter可以与现有的代码一起工作。在全世界,Flutter正在被越来越多的开发者和组织使用,并且Flutter是完全免费、开源的。

  1. 快速开发
  2. 富有表现力和灵活的UI
  3. 原生性能

1. 工具和相关文档

1.1 相关工具

  1. Windows 7 或更高系统 (64-bit)
  2. Git命令行工具 下载Git工具
  3. Android Studio 或 VSCode

1.2 相关文档

  1. Flutter中文网,包含教程、文档、示例等。
  2. pub.dev,Flutter第三方插件仓库。

建议有稳定的翻墙工具,否则过程可能比较痛苦!
建议有稳定的翻墙工具,否则过程可能比较痛苦!
建议有稳定的翻墙工具,否则过程可能比较痛苦!


2 安装 Flutter SDK

Dart SDK 已经捆绑在 Flutter 里,无需再单独安装 Dart

2.1 配置国内镜像

  1. 国内访问Flutter有时可能会受到限制,Flutter官方为中国开发者搭建了临时镜像,大家可以将如下环境变量加入到用户环境变量中。
  2. 此镜像为临时镜像,并不能保证一直可用,读者可以参考详情请参考 Using Flutter in China 以获得有关镜像服务器的最新动态。
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn

添加用户变量

2.2 安装 Flutter SDK

推荐:使用 Git 克隆 Flutter 库到本地。(如克隆到 C:/Flutter 下,不要放在高权限的文件夹下,如 C:\Program Files\,尽量使用英文路径)

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

其他方法(以下方法鄙人都失败了,运行报错且下载慢,你可以试试):

  1. Flutter官网下载其最新可用的安装包,下载
  2. Flutter Github 项目去下载安装包 ,前去

在安装目录的文件下找到 flutter_console.bat,双击运行并启动Flutter命令行,接下来,你就可以在Flutter命令行运行flutter命令了。
运行Flutter

2.3 更新环境变量

环境变量追加 flutter\bin 的全路径,如图。
更新环境变量

2.4 测试 Flutter

sdk安装成功,环境变量配置成功。在任意路径下执行 flutter version 应能看到版本号。
测试查看版本号

2.5 运行 flutter doctor

打开一个新的命令提示符或PowerShell窗口并运行以下命令以查看是否需要安装任何依赖项来完成安装:

flutter doctor

该命令检查您的环境并在终端窗口中显示报告。 仔细检查命令行输出以获取可能需要安装的其他软件或进一步需要执行的任务(以粗体显示),例如:

[-] Android toolchain - develop for Android devices
    • Android SDK at D:\Android\sdk
    ✗ Android SDK is missing command line tools; download from https://goo.gl/XxQghQ
    • Try re-installing or updating your Android SDK,
      visit https://flutter.io/setup/#android-setup for detailed instructions.

第一次运行一个flutter命令(如flutter doctor)时,它会下载它自己的依赖项并自行编译。以后再运行就会快得多。


如果你刚走到这步,会提示缺少很多依赖,鄙人已安装成功,输出信息是这样的:

D:\flutter>flutter doctor
Doctor summary (to see all details, run flutter doctor -v):
[√] Flutter (Channel stable, v1.12.13+hotfix.8, on Microsoft Windows [Version 10.0.18362.476], locale zh-CN)

[!] Android toolchain - develop for Android devices (Android SDK version 29.0.3)
    ! Some Android licenses not accepted.  To resolve this, run: flutter doctor --android-licenses
[√] Android Studio (version 3.6)
[!] IntelliJ IDEA Ultimate Edition (version 2019.2)
    X Flutter plugin not installed; this adds Flutter specific functionality.
    X Dart plugin not installed; this adds Dart specific functionality.
[√] Connected device (1 available)

! Doctor found issues in 2 categories.

输出信息大体是说:

  1. Flutter SDK 安装成功和版本号。
  2. Android SDK 安装成功和版本号。
  3. Android Studio 正常。(包含:安装、SDK配置、Flutter插件等都正常)
  4. IDEA 编辑器缺少 FlutterDart 插件。( Android Studio已正常,idea不是必须,不用管)
  5. 连接了一个设备。(电脑连接真机正常,会自动检测到)

3. 安装 Android Studio 和 Android SDK

  1. 推荐先安装 Android Studio,缺少啥依赖会提示,下载方便,这点比 VSCode 强。
  2. 所有依赖安装完毕后,根据习惯使用适合编辑器。

3.1 下载 Android Studio

  1. Android 官网 下载,需要翻墙
  2. Android Studio 中文网站 下载
  3. 百度网盘(Android Studio 3.6.1版本):链接:https://pan.baidu.com/s/1je8d4EHwChHPhz6fTXGpCw 提取码:n3oc

3.2 安装 Android Studio 和 Android SDK

  1. 安装 Android Studio,基本属于一直下一步那种。
  2. 安装启动,会提示你安装 Android SDK、工具啥的。
  3. 可在 File -> Settings -> Appearance & Behavior -> System Settings -> Android SDK 中进行SDK的路径配置、查看、下载和更新。
  4. 下图是我的sdk和工具的安装项,供参考,已上传到网盘,安装困难户可以用我的SDK试试。链接:https://pan.baidu.com/s/12Vdba27j1AA2BO6Vkp3PrQ 提取码:s8ns
    Platforms
    Tools

3.3 安装 Flutter 插件

  1. Android Studio:File -> Settings -> Plugins 中搜索并安装 Flutter 插件。
  2. VSCode:搜索并安装 Flutter 插件。
  3. 通常安装 Flutter 插件,会自动安装 Dart ,无需再单独 Dart

Android Studio安装Flutter,老子卡了好久!各种安装不上,还不支持 install Plugin from Disk…,各种蛋疼。

3.4 打完收工

正常情况下,此时环境应该大功告成了,可以运行 flutter doctor 查看是否无问题。

4 新建并运行 Flutter 应用

4.1 Android Studio 新建并运行

  1. File -> New -> New Flutter Project... 新建 Flutter 项目。
  2. 项目目录中,您应用程序的代码位于 lib/main.dart
  3. 连接真机或模拟器,启动。
    Android Studio 工具栏

4.2 VSCode 新建并运行

  1. 新建项目:Ctrl + Shift + P 后,选择 Fluttr: New Project
  2. 项目目录中,您应用程序的代码位于 lib/main.dart
  3. 连接真机或模拟器,按 F5 键或调用 Debug -> Start Debugging
    VSCode新建应用
    启动

4.3 手机效果,支持热更新

在这里插入图片描述

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐