Flutter 实战经验(五):在 VS Code 里开发 Flutter 应用
wptr33 2025-04-26 21:40 14 浏览
本文将与你一起回顾如何在 VS Code 里进行 Flutter 应用的开发。
1. 安装和配置
根据 编辑工具设定 的指引来安装 Dart 和 Flutter 扩展(也叫做插件)。
1.1 更新扩展程序
扩展的更新会定期发布。默认情况下,当有可用的更新时 VS Code 会自动更新扩展。
手动安装更新:
(1)点击侧边栏的扩展按钮
(2)如果 Flutter 扩展显示有可用更新,点击更新按钮,然后重载。
(3)重启 VS Code。
2. 创建项目
2.1 新建项目
通过 Flutter 入门应用模板新建 Flutter 项目:
(1)打开命令面板(Ctrl+Shift+P (macOS 用 Cmd+Shift+P))。
(2)选择 Flutter: New Project 命令然后按 Enter。
(3)输入你想要的项目名。
(4)选择项目地址。
2.2 从现有源代码打开项目
打开现有 Flutter 项目:
(1)在 IDE 主窗口点击 File > Open。
(2)选择存放现有 Flutter 源代码文件的目录。
(3)点击 Open。
3. 编写代码及查看问题
Flutter 扩展执行代码分析,它提供:
- 语法高亮。
- 基于丰富输入分析的代码补全。
- 导航到类型声明(Go to Definition 或 F12)和查找类型引用(Find All References 或 Shift+F12)。
- 查看所有当前代码问题(View > Problems 或 Ctrl+Shift+M (macOS 用 Cmd+Shift+M))。所有问题分析都会在 Problems 面板展示:
4. 运行和调试
备忘
有多种方式能够调试你的应用
- 使用 DevTools,它是一个运行在浏览器中的调试以及性能测试工具集。DevTools 取代了前一代基于浏览器的性能测试工具 Observatory,它包含了以前仅适用于 Android Studio 和 IntelliJ 的功能,例如 Flutter inspector。
- 使用 VS Code 的内置调试功能,例如设置断点。
以下说明描述了 VS Code 可用的功能。更多使用 DevTools 的详细信息请参考 DevTools 中的 Running DevTools from VS Code 文档。
在 IDE 主窗口点击 Debug > Start Debugging 或按 F5 开启调试。
4.1 选择目标设备
当一个 Flutter 项目在 VS Code 中打开,你会在状态栏看到一些 Flutter 特有项,包括 Flutter SDK 版本和设备名称(或者无设备信息)。
备忘
- 如果你没看到 Flutter 版本号或者设备信息,你的项目可能不被识别为一个 Flutter 项目。请确认 VS Code Workspace Folder 的目录中是否含有 pubspec.yaml。
- 如果状态栏显示无设备表明 Flutter 没有发现任何已连接的 IOS、Android 或者模拟器。你需要连接设备或者启动模拟器。
Flutter 扩展会自动选择上次连接的设备。然而,如果你有多个设备/模拟器连接,点击状态栏的 device 查看屏幕顶部的选择列表。选择你要用来运行或调试的设备。
备忘
如果你尝试运行 web 应用,但是 Chrome (web) 并不在目标列表中,请检查是否启用了 web,在 Building a web application 中进行了介绍。
4.2 无断点运行
(1)在 IDE 主窗口点击 Debug > Start Without Debugging,或者按 Ctrl+F5。状态栏变橙色说明你正处于调试模式。
4.3 断点运行
(1)如果需要,在源代码中设置断点。
(2)在 IDE 主窗口点击 Debug > Start Debugging 或按 F5。
- 左侧的调试侧边栏显示堆栈帧和变量。底部的调试控制台面板显示输出的日志详情。调试基于默认的配置。也可以通过点击调试侧边栏顶部的齿轮创建 launch.json 文件自定义调试。你可以修改里面的值。
5. 快速编辑和刷新开发周期
Flutter 提供一流的开发周期,通过 Stateful Hot Reload 特性使你在几乎修改代码的同时就能看到变化。详情请看 使用热重载。
6. 进阶调试
6.1 可视化布局问题调试
在调试会话期间,命令面板 和 Flutter inspector 会添加一些额外的调试命令,包括:
- 切换 Baseline 绘制
- 每个 RenderBox 在底部绘制一条线。
- 切换重绘 Rainbow
- 重新绘制时在图层上改变颜色。
- 切换慢模式横幅
- 减慢动画以启用视觉检查。
- 切换 debug 模式横幅显示
- 在运行调试构建时隐藏 debug 模式的横幅 (banner)。
6.2 调试外部库
默认情况下,Flutter 扩展禁止调试外部库。启用步骤:
(1)选择 Settings > Extensions > Dart Configuration
(2)勾选 Debug External Libraries 选项。
7. Flutter 代码编辑提示
如果你有其他我们应该提供的代码提示建议,请 [告诉我们][]!
7.1 代码辅助和快速修复
代码辅助功能是特定代码标识符相关的代码修改。当光标放在 Flutter widget 上时,黄色灯泡图标会指示可用的修改,可以通过点击灯泡进行修改,或者使用快捷键 Ctrl+. (macOS 用 Cmd+.),如图所示:
快速修复跟辅助类似,当一段代码有错误并且可以辅助修正时才会显示。
Widget 嵌套辅助
当你有个 widget 想包装进一个容器 widget 时,例如你想把 widget 放入一个 Row 或者 Column。
Widget 列表嵌套辅助
和上面的辅助类似,但它嵌套的是一个 widget 的列表,而不是单个的 widget。
child 和 children 转换辅助
将 child 转换成 children,并且把参数值写进一个 list。
7.2 代码片段
代码片段可以用来加速输入通用类型代码段。通过输入前缀来调用,然后从代码完成窗口中选择:
Flutter 扩展包含以下片段:
- 前缀 stless:创建一个 StatelessWidget 子类。
- 前缀 stful:创建一个 StatefulWidget 子类,并且和 State 子类关联。
- 前缀 stanim:创建一个 StatefulWidget 子类,并且把包含字段初始化的 State 子类和一个 AnimationController 关联。
你也可以通过在 命令面板 执行Configure User Snippets来自定义片段。
7.3 键盘快捷键
热重载
调试期间,在调试工具栏点击重启按钮,或者按 Ctrl+Shift+F5 (macOS 用 Cmd+Shift+F5)执行热重载。
键盘映射可以在 命令面板 执行Open Keyboard Shortcuts修改。
7.4 热重载和热重启
热重载的工作原理是将更新后的代码注入 Dart VM(虚拟机)。不仅包括添加新类,还包括添加方法和字段到已有的类中。但有些类型的代码是无法被热重载的:
- 全部变量的初始化
- 静态变量的初始化
- 应用的 main() 方法
对于这些更改,你无需结束调试过程而直接热重启 (hot restart) 你的应用。要执行热重启,执行 命令面板 的 Flutter:热重启命令,或者按 Ctrl+F5。
8. 故障排除
8.1 已知问题和反馈
所有已知 bug 在这个 issue 列表中记录:Dart 和 Flutter 扩展 GitHub issue 追踪。
我们非常欢迎 bugs/issues 和特性请求的反馈。在提交新 issue 之前:
- 在 issue 列表中查找看该问题是否已被记录。
- 确保你已经更新最新版本插件。
提交新 issue 时,请包含 flutter doctor 输出。
- 上一篇:Flutter 2 的Windows 开发试验
- 下一篇:Flutter——路由
相关推荐
- 每天一个编程技巧!掌握这7个神技,代码效率飙升200%
-
“同事6点下班,你却为改BUG加班到凌晨?不是你不努力,而是没掌握‘偷懒’的艺术!本文揭秘谷歌工程师私藏的7个编程神技,每天1分钟,让你的代码从‘能用’变‘逆天’。文末附《Python高效代码模板》,...
- Git重置到某个历史节点(Sourcetree工具)
-
前言Sourcetree回滚提交和重置当前分支到此次提交的区别?回滚提交是指将改动的代码提交到本地仓库,但未推送到远端仓库的时候。...
- git工作区、暂存区、本地仓库、远程仓库的区别和联系
-
很多程序员天天写代码,提交代码,拉取代码,对git操作非常熟练,但是对git的原理并不甚了解,借助豆包AI,写个文章总结一下。Git的四个核心区域(工作区、暂存区、本地仓库、远程仓库)是版本控制的核...
- 解锁人生新剧本的密钥:学会让往事退场
-
开篇:敦煌莫高窟的千年启示在莫高窟321窟的《降魔变》壁画前,讲解员指着斑驳色彩说:"画师刻意保留了历代修补痕迹,因为真正的传承不是定格,而是流动。"就像我们的人生剧本,精彩章节永远...
- Reset local repository branch to be just like remote repository HEAD
-
技术背景在使用Git进行版本控制时,有时会遇到本地分支与远程分支不一致的情况。可能是因为误操作、多人协作时远程分支被更新等原因。这时就需要将本地分支重置为与远程分支的...
- Git恢复至之前版本(git恢复到pull之前的版本)
-
让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)方法一:gitreset...
- 如何将文件重置或回退到特定版本(怎么让文件回到初始状态)
-
技术背景在使用Git进行版本控制时,经常会遇到需要将文件回退到特定版本的情况。可能是因为当前版本出现了错误,或者想要恢复到之前某个稳定的版本。Git提供了多种方式来实现这一需求。...
- git如何正确回滚代码(git命令回滚代码)
-
方法一,删除远程分支再提交①首先两步保证当前工作区是干净的,并且和远程分支代码一致$gitcocurrentBranch$gitpullorigincurrentBranch$gi...
- [git]撤销的相关命令:reset、revert、checkout
-
基本概念如果不清晰上面的四个概念,请查看廖老师的git教程这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改存起来。后来用多了,也就明白了为什么。gi...
- 利用shell脚本将Mysql错误日志保存到数据库中
-
说明:利用shell脚本将MYSQL的错误日志提取并保存到数据库中步骤:1)创建数据库,创建表CreatedatabaseMysqlCenter;UseMysqlCenter;CREATET...
- MySQL 9.3 引入增强的JavaScript支持
-
MySQL,这一广泛采用的开源关系型数据库管理系统(RDBMS),发布了其9.x系列的第三个更新版本——9.3版,带来了多项新功能。...
- python 连接 mysql 数据库(python连接MySQL数据库案例)
-
用PyMySQL包来连接Python和MySQL。在使用前需要先通过pip来安装PyMySQL包:在windows系统中打开cmd,输入pipinstallPyMySQL ...
- mysql导入导出命令(mysql 导入命令)
-
mysql导入导出命令mysqldump命令的输入是在bin目录下.1.导出整个数据库 mysqldump-u用户名-p数据库名>导出的文件名 mysqldump-uw...
- MySQL-SQL介绍(mysql sqlyog)
-
介绍结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同...
- MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南
-
在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- 每天一个编程技巧!掌握这7个神技,代码效率飙升200%
- Git重置到某个历史节点(Sourcetree工具)
- git工作区、暂存区、本地仓库、远程仓库的区别和联系
- 解锁人生新剧本的密钥:学会让往事退场
- Reset local repository branch to be just like remote repository HEAD
- Git恢复至之前版本(git恢复到pull之前的版本)
- 如何将文件重置或回退到特定版本(怎么让文件回到初始状态)
- git如何正确回滚代码(git命令回滚代码)
- [git]撤销的相关命令:reset、revert、checkout
- 利用shell脚本将Mysql错误日志保存到数据库中
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)