【Flutter】Dart:环境搭建
Flutter 是一个基于 Dart 的跨平台开发框架,可以帮助我们快速构建移动应用程序。在开始 Flutter 开发之前,我们需要先搭建 Dart 的开发环境,并配置合适的编辑器,比如 VSCode。本教程将引导你一步步完成 Dart 和 Flutter 的环境搭建,并配置 VSCode 以提高开发效率。
安装 Flutter 和 Dart SDK
Flutter 包含 Dart SDK,因此安装 Flutter 后会自动包含 Dart,无需单独安装 Dart SDK。
下载并安装 Flutter SDK
- 访问 Flutter 官方下载页面:Flutter 下载
- 根据你的操作系统选择合适的版本下载(Windows、macOS 或 Linux)。
解压并设置环境变量
-
Windows:
- 下载后将 Flutter SDK 解压到你想要安装的位置,比如
C:\src\flutter。 - 打开
系统属性 -> 环境变量 -> 系统变量 -> Path,点击 “编辑”,将 Flutter 的bin目录(如C:\src\flutter\bin)添加到系统环境变量中。
- 下载后将 Flutter SDK 解压到你想要安装的位置,比如
-
macOS 和 Linux:
-
打开终端,将下载的 Flutter SDK 解压到合适的路径(如
~/development/flutter)。 -
编辑
~/.bashrc或~/.zshrc文件,添加以下内容:export PATH="$PATH:`pwd`/flutter/bin" -
然后执行
source ~/.bashrc或source ~/.zshrc使路径生效。
-
验证安装
打开终端(或命令提示符),运行以下命令检查 Flutter 是否安装成功:
flutter --version
如果输出 Flutter 的版本信息,说明安装成功。
安装 Flutter 依赖
运行以下命令安装 Flutter 依赖并检测系统配置:
flutter doctor
flutter doctor 会显示系统配置的状态,确保所有必需的依赖(如 Android Studio、Xcode 等)都已安装。如果有缺失的依赖,根据提示安装即可。
安装并配置 VSCode
VSCode 是轻量且强大的编辑器,非常适合 Flutter 和 Dart 的开发。以下是配置步骤:
下载并安装 VSCode
- 访问 VSCode 官网 并下载安装程序。
- 安装完成后,打开 VSCode。
安装 Dart 和 Flutter 插件
-
打开 VSCode 后,点击左侧扩展市场图标(或使用快捷键
Ctrl+Shift+X),在搜索框中分别搜索并安装:DartFlutter
这些插件将为你提供 Dart 和 Flutter 的语法高亮、智能提示、调试等功能。
配置 Flutter 项目
- 在 VSCode 中,按下
Ctrl+Shift+P打开命令面板,输入Flutter: New Project并按下回车。 - 选择项目的目录,并为你的项目命名,VSCode 会自动生成 Flutter 项目文件结构。
配置 Android 模拟器或 iOS 模拟器
-
Android 模拟器:
- 打开 Android Studio,确保已经安装了 Android SDK 和虚拟设备管理器(AVD)。
- 创建一个 Android 虚拟设备并启动。
- 在 VSCode 中,可以通过运行
flutter devices查看可用设备。
-
iOS 模拟器(仅限 macOS):
- 确保已安装 Xcode 并且配置了 iOS 开发环境。
- 在终端中运行
open -a Simulator启动 iOS 模拟器。
Dart 代码的编写与运行
创建 Dart 文件
-
在 Flutter 项目中,打开
lib/main.dart文件。你可以看到 Flutter 默认的项目结构。 -
如果你只想练习 Dart 语言,可以新建一个 Dart 文件,例如
hello.dart:void main() {print('Hello, Dart!'); }
运行 Dart 文件
-
打开终端,在 VSCode 中使用以下命令直接运行 Dart 文件:
dart run hello.dart -
或者在 VSCode 中安装
Code Runner插件,然后通过点击右上角的运行按钮来执行 Dart 文件。
调试 Flutter 应用
运行 Flutter 应用
- 打开
lib/main.dart文件。 - 按
F5启动调试模式,VSCode 将自动运行 Flutter 应用并连接到模拟器或设备。
热重载与热重启
- 热重载:保存代码时会自动应用更改,极大提升开发效率。你也可以在终端运行
r执行热重载。 - 热重启:按
Shift+R,用于重新启动应用并应用代码的全局变更。
总结
通过上述步骤,你应该已经成功安装并配置了 Dart 和 Flutter 的开发环境,并且能使用 VSCode 编写和调试 Flutter 应用。整个流程可以分为以下几个步骤:
- 安装并配置 Flutter SDK 和 Dart 环境。
- 安装并配置 VSCode 编辑器。
- 学习如何创建和运行 Dart 文件以及 Flutter 项目。
- 通过模拟器或真机调试 Flutter 应用。
接下来,你可以开始深入学习 Flutter 开发,探索更多组件和功能。希望这个教程能帮助你顺利进入 Flutter 开发的世界!
相关文章:
【Flutter】Dart:环境搭建
Flutter 是一个基于 Dart 的跨平台开发框架,可以帮助我们快速构建移动应用程序。在开始 Flutter 开发之前,我们需要先搭建 Dart 的开发环境,并配置合适的编辑器,比如 VSCode。本教程将引导你一步步完成 Dart 和 Flutter 的环境搭建…...
OpenCV高级图形用户界面(10)创建一个新的窗口函数namedWindow()的使用
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 创建一个窗口。 函数 namedWindow 创建一个可以作为图像和跟踪条占位符的窗口。创建的窗口通过它们的名字来引用。 如果已经存在同名的窗口&am…...
水题四道。
我的 水题四道--题目目录 问题 A: 依次输出第k小整数 代码1 问题 B: 第k小整数(knumber) 代码2 树的统计 代码3 枪声问题 代码4 问题 A: 依次输出第k小整数 现有n个正整数,n≤10000,要求出这n个正整数中的第1小的整数,第2小的整数…...
upload-labs靶场Pass-05
upload-labs靶场Pass-05 大小写绕过 $deny_ext array(“.php”,“.php5”,“.php4”,“.php3”,“.php2”,“.html”,“.htm”,“.phtml”,“.pht”,“.pHp”,“.pHp5”,“.pHp4”,“.pHp3”,“.pHp2”,“.Html”,“.Htm”,“.pHtml”,“.jsp”,“.jspa”,“.jspx”,“.jsw”…...
【AIGC】解锁高效GPTs:ChatGPT-Builder中系统提示词Prompt的设计与应用
博客主页: [小ᶻZ࿆] 本文专栏: AIGC | ChatGPT 文章目录 💯前言💯系统提示词系统提示词的作用与重要性系统提示词在构建GPTs中的作用结论 💯ChatGPT-Builder系统提示词的详细解读OpenAI为Builder编写的系统提示词系统提示词对…...
【JavaEE初阶】深入理解网络编程—使用UDP协议API实现回显服务器
前言 🌟🌟本期讲解关于TCP/UDP协议的原理理解~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 🎆那么废话不…...
C语言复习第3章 函数
目录 一、函数介绍1.1 函数是什么1.2 C语言中函数的分类1.3 函数原型1.4 高内聚 低耦合1.5 C语言main函数的位置 二、函数的参数2.1 实参和形参2.2 函数的参数(实参)可以是表达式2.3 传值与传址(swap函数)2.4 明确形参是实参的临时拷贝2.5 void(如果不写函数返回值 默认是int)2…...
Golang | Leetcode Golang题解之第491题非递减子序列
题目: 题解: var (temp []intans [][]int )func findSubsequences(nums []int) [][]int {ans [][]int{}dfs(0, math.MinInt32, nums)return ans }func dfs(cur, last int, nums []int) {if cur len(nums) {if len(temp) > 2 {t : make([]int, len(…...
conan安装方法简介
因为conan是使用python开发的,所以使用conan需要先安装python环境,这里就不展开python的安装方法了。 conan安装有多种方法,但是比较推荐也是比较简单的一种方法是使用python的pip包管理器安装,相关方法如下(Windows和…...
Java面试指南:Java基础介绍
这是《Java面试指南》系列的第1篇,本篇主要是介绍Java的一些基础内容: 1、Java语言的起源 2、Java EE、Java SE、Java ME介绍 3、Java语言的特点 4、Java和C的区别和联系? 5、面向对象和面向过程的比较 6、Java面向对象的三大特性:…...
【mod分享】波斯王子遗忘之沙高清重置,纹理,字体,贴图全部重置,特效增强,支持光追
各位好,今天小编给大家带来一款新的高清重置MOD,本次高清重置的游戏叫《波斯王子:遗忘之沙》。 《波斯王子:遗忘之沙》是由育碧(Ubisoft)开发并发行的一款动作类游戏,于2010年5月18日发行。游戏…...
【计网笔记】物理层
设备 中继器:延长信号传播长度集线器:RJ45接口,无碰撞检测 接口特性 不属于物理层接口规范定义范畴的是(C) A. 接口形状 B. 引脚功能 C. 物理地址 D. 信号电平 传输媒体 导引型媒体 双绞线 减少对相邻导线的电磁…...
《计算机视觉》—— 基于 dlib 库的方法将两张人脸图片进行换脸
声明:此篇文章所用的明星照片只为用于演示代码的效果,无诋毁她人肖像之意 一、案例实现的思想 此案例的核心是基于人脸68个关键点检测模型来实现的,人脸68个关键带点检测后的效果如下: 通过对上图中红色区域的转换,…...
查找与排序-交换排序
交换排序是基于“比较”和“交换”两种操作来实现的排序方法 。 由于选择“比较”的基准元素不同,可将交换排序分为以下两种: 冒泡排序快速排序 一、冒泡排序 1.冒泡排序基本思想 因为其实现与气泡从水中往上冒的过程类似而得名。 每一趟的…...
数据结构与算法:高级数据结构与实际应用
目录 14.1 跳表 14.2 Trie树 14.3 B树与 B树 14.4 其他高级数据结构 总结 数据结构与算法:高级数据结构与实际应用 本章将探讨一些高级数据结构,这些数据结构在提高数据存取效率和解决复杂问题上起到重要作用。这些高级数据结构包括跳表࿰…...
【win11】终端/命令提示符/powershell美化
文章目录 1.设置字体1.1. 打开win11的终端/命令提示符/powershell其中之一1.2. 打开终端设置,修改所有终端默认字体为新宋体 2. 修改powershell背景色为蓝色 win11的默认终端/命令提示符/powershell主题风格让人感觉与win10撕裂太大,尤其是字体、背景色&…...
三元损失(Triplet Loss)详解
文章目录 前言一、三元损失的核心思想二、数学公式三、损失函数的解释四、三元损失的优势五、应用场景前言 三元损失(Triplet Loss)是一种广泛应用于度量学习(Metric Learning)中的损失函数,尤其在人脸识别、图像检索等任务中表现优异。三元损失的基本思想是通过定义一个…...
1. 解读DLT698.45-2017通信规约--预连接响应
国家电网有限公司企业标准,面向对象的用电信息数据交换协议DLT698.45-2017 为提高用电信息采集系统的业务适应性、采集效率、安全性和数据溯源性,规范用电信息数据交换协议的通信架构、数据链路层、应用层、接口类与对象标识,制定本标准。 …...
基于小波图像去噪的MATLAB实现
论文背景 数字图像处理(Digital Image Processing,DIP)是指用计算机辅助技术对图像信号进行处理的过程。数字图像处理最早出现于 20世纪50年代,随着过去几十年来计算机、网络技术和通信的快速发展,为信号处理这个学科领域的发展奠定了基础&a…...
[数据结构]栈的实现与应用
文章目录 一、引言二、栈的基本概念1、栈是什么2、栈的实现方式对比3、函数栈帧 三、栈的实现1、结构体定义2、初始化3、销毁4、显示5、数据操作 四、分析栈1、优点2、缺点 五、总结1、练习题2、源代码 一、引言 栈,作为一种基础且重要的数据结构,在计算…...
超越Smooth L1!揭秘Wing Loss在人脸对齐中的梯度优化艺术(附PyTorch代码剖析)
1. 为什么我们需要超越Smooth L1? 在计算机视觉领域,人脸关键点检测一直是个既基础又具有挑战性的任务。记得我第一次尝试用深度学习解决这个问题时,就像大多数初学者一样,毫不犹豫地选择了L2损失函数。结果发现模型在测试集上的表…...
Phi-3 Forest Lab应用场景:数据工程师——SQL转Pandas+异常检测逻辑生成
Phi-3 Forest Lab应用场景:数据工程师——SQL转Pandas异常检测逻辑生成 1. 数据工程师的日常痛点 数据工程师每天都要处理大量数据转换和分析任务,其中两个最常见的工作是: SQL到Pandas的转换:需要将业务团队提供的SQL查询转换…...
浙江清洁拖把这样选
随着现代生活节奏的加快和健康家居理念的普及,家庭清洁工具正经历着一场深刻的智能化、便捷化变革。在众多品类中,清洁拖把作为地面清洁的核心工具,其技术演进与产品创新直接关系到清洁效率和用户体验。本文将聚焦行业痛点、技术方案与应用效…...
极客专属:OpenClaw命令行操控Qwen3-14B镜像高级技巧
极客专属:OpenClaw命令行操控Qwen3-14B镜像高级技巧 1. 为什么需要命令行操控OpenClaw 第一次接触OpenClaw时,我和大多数人一样被它的Web控制台吸引。可视化界面确实降低了使用门槛,但当我尝试构建自动化工作流时,发现图形界面反…...
企业级RESTful API设计终极指南:10个进阶技巧助力构建高性能接口
企业级RESTful API设计终极指南:10个进阶技巧助力构建高性能接口 【免费下载链接】restful-api-design-references RESTful API 设计参考文献列表,可帮助你更加彻底的了解REST风格的接口设计。 项目地址: https://gitcode.com/gh_mirrors/re/restful-a…...
开发者利器:OpenClaw+千问3.5-9B自动生成单元测试
开发者利器:OpenClaw千问3.5-9B自动生成单元测试 1. 为什么需要AI生成单元测试 作为一名长期奋战在一线的开发者,我深知单元测试的重要性——它不仅是代码质量的守护者,更是重构时的安全网。但现实情况是,在紧张的开发周期中&am…...
结合YOLOv8的目标检测:为LiuJuan生成画作智能添加题跋与印章
结合YOLOv8的目标检测:为AI生成画作智能添加题跋与印章 1. 引言 想象一下,你刚用AI工具生成了一幅意境优美的山水画,画中山水空灵,笔触细腻,颇有几分古意。但总觉得少了点什么——对,就是那种传统国画特有…...
小白友好:Neeshck-Z-lmage_LYX_v2部署教程,详解显卡驱动兼容性与CUDA锁定
小白友好:Neeshck-Z-lmage_LYX_v2部署教程,详解显卡驱动兼容性与CUDA锁定 1. 工具简介:为什么选择它? 想体验一款功能强大、操作简单的国产文生图工具,却总在环境配置这一步卡住?特别是显卡驱动和CUDA版本…...
华新嘉华:如何做好GEO?记住!简单的内容堆砌达不到效果
在生成式AI搜索全面重塑信息获取方式的当下,越来越多的企业开始布局GEO(生成式引擎优化),希望抢占AI搜索这一新兴流量入口。然而,一个不容忽视的现象正在蔓延:大量企业投入资源、批量生产内容,…...
LLM强化学习从入门到精通:Composition-RL全解析,收藏这篇就够了!
🎯 为什么我们需要Composition-RL? 想象一下:你正在备考数学竞赛,一开始做的都是基础题。随着练习增多,你能轻松答对所有基础题,但这些简单题已经无法帮你进步了——你需要更难的题目来提升能力。 这正是…...
