Flutter 开发3:创建第一个Flutter应用

Step 1: 安装Flutter

1.1 下载Flutter SDK

首先,你需要访问Flutter官方网站下载最新的Flutter SDK。选择适合你操作系统的安装包。

$ cd ~/development
$ unzip ~/Downloads/flutter_macos_2.2.3-stable.zip

1.2 更新环境变量

接下来,你需要将Flutter的bin目录添加到你的环境变量中。这样你就可以在任何地方运行Flutter命令。

$ export PATH="$PATH:`pwd`/flutter/bin"

Step 2: 安装Android Studio

Flutter需要一个Android平台来运行和测试应用程序。最简单的方式就是安装Android Studio,它包含了所有你需要的工具。

2.1 下载并安装Android Studio

访问Android Studio官方网站下载最新的Android Studio版本。然后按照提示进行安装。

2.2 安装Flutter和Dart插件

在Android Studio中,你需要安装Flutter和Dart插件来支持Flutter应用开发。

$ flutter doctor

这个命令将检查你的环境,并显示任何需要解决的问题。如果没有问题,你就可以开始创建你的第一个Flutter应用了。

Step 3: 创建你的第一个Flutter应用

3.1 使用Flutter命令行工具

使用Flutter命令行工具是创建新的Flutter应用最简单的方式。只需要运行以下命令:

$ flutter create my_app
$ cd my_app

这将创建一个新的Flutter应用,并且所有的代码都放在my_app目录下。
在这里插入图片描述

3.2 运行你的应用

在你的设备或模拟器上运行你的应用,只需要运行以下命令:

$ flutter run

在这里插入图片描述

现在你应该可以看到你的第一个Flutter应用在你的设备或模拟器上运行了。

Step 4: 探索你的应用

现在你已经创建了你的第一个Flutter应用,是时候更深入地了解它的工作原理了。让我们从main.dart文件开始。

$ cd lib
$ nano main.dart

这个文件是你的应用的入口点。它定义了一个main函数,这个函数调用了runApp函数,runApp函数接受一个Widget作为参数。在这个例子中,这个Widget是MyApp类的一个实例。

Step 5: 自定义你的应用

Flutter使用Widget来构建UI。每个Widget都是不可变的,一旦你的Widget被创建,你就不能改变它。但是,你可以通过改变它的状态来改变它的外观和行为。

5.1 创建一个新的Widget

让我们创建一个新的Widget,它包含一个按钮和一个文本。当你点击按钮时,文本将更新。

$ nano lib/main.dart

在这个文件中,你需要定义一个新的StatefulWidget。这个Widget有一个状态,当你点击按钮时,状态将更新,然后Widget将重新构建,显示新的文本。

class MyCustomWidget extends StatefulWidget {_MyCustomWidgetState createState() => _MyCustomWidgetState();
}class _MyCustomWidgetState extends State<MyCustomWidget> {int _counter = 0;void _incrementCounter() {setState(() {_counter++;});}Widget build(BuildContext context) {return Container(child: Column(children: <Widget>[Text('You have pushed the button $_counter times.'),RaisedButton(onPressed: _incrementCounter,child: Text('Increment'),),],),);}
}

5.2 使用你的新Widget

现在你已经创建了一个新的Widget,你可以在你的应用中使用它。让我们把它添加到MyApp Widget中。

class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('My First Flutter App'),),body: MyCustomWidget(),),);}
}

现在,当你运行你的应用时,你应该可以看到你的新Widget,它包含一个显示文本和一个按钮。每次你点击按钮,文本都会更新。

5.3 测试你的应用

Flutter提供了一个强大的测试框架,你可以使用它来测试你的应用。让我们为你的新Widget写一个测试。

$ cd test
$ nano widget_test.dart

在这个文件中,你需要定义一个新的测试,这个测试将检查当你点击按钮时,文本是否正确更新。

void main() {testWidgets('MyCustomWidget updates text when button is pressed', (WidgetTester tester) async {await tester.pumpWidget(MyApp());expect(find.text('You have pushed the button 0 times.'), findsOneWidget);await tester.tap(find.byType(RaisedButton));await tester.pump();expect(find.text('You have pushed the button 1 times.'), findsOneWidget);});
}

你可以运行这个测试,看看你的Widget是否正常工作。

$ flutter test

如果你的测试通过,那么你可以确信你的Widget正常工作。

Step 6: 构建和发布你的应用

当你对你的应用满意,并准备发布它时,你需要构建它。Flutter提供了一个命令行工具,你可以使用它来构建你的应用。

6.1 构建你的应用

你可以使用以下命令来构建你的应用:

$ flutter build apk --release

这将构建一个适用于Android的APK文件。如果你想为iOS构建你的应用,你可以使用flutter build ios --release

6.2 发布你的应用

一旦你构建了你的应用,你就可以发布它了。你可以将它上传到Google Play Store或Apple App Store,或者你可以直接将APK文件提供给你的用户下载。

在这个教程中,你学习了如何创建你的第一个Flutter应用,如何自定义它,如何测试它,以及如何构建和发布它。虽然这只是一个简单的开始,但是Flutter提供了许多工具和库,你可以使用它们来创建更复杂的应用。现在,你已经掌握了基础知识,你可以开始探索Flutter的更多功能了。

享受你的Flutter旅程!

Step 7: 进一步学习

现在你已经掌握了Flutter的基础知识,你可能想要探索更多的内容。让我们看看你可以学习的一些主题。

7.1 使用外部包

Flutter有一个非常活跃的社区,他们创建了许多用于解决常见问题的包。你可以在pub.dev找到这些包。

7.2 使用动画

Flutter有一个强大的动画库,你可以使用它来创建复杂的UI动画。

7.3 使用数据库

如果你的应用需要存储大量的用户数据,你可能需要使用数据库。Flutter支持SQLite,你可以使用它来创建本地数据库。

7.4 使用网络服务

如果你的应用需要与服务器通信,你可能需要使用HTTP包。你可以使用它来发送GET和POST请求。

7.5 使用Flutter for Web

Flutter不仅可以用于构建移动应用,还可以用于构建网页应用。你可以使用和构建移动应用相同的代码库来构建网页应用。

结语

在这个教程中,你学习了如何创建你的第一个Flutter应用,如何自定义它,如何测试它,以及如何构建和发布它。你还了解了一些可以进一步学习的主题。Flutter是一个强大而灵活的框架,无论你是一个新手还是一个经验丰富的开发者,都可以使用它来创建美观而高效的应用。

享受你的Flutter旅程!

感谢阅读, Best Regards!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/664435.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络异常案例四_IP异常

问题现象 终端设备离线&#xff0c;现场根据设备ip&#xff0c;ping不通。查看路由器。 同一个路由器显示的终端设备&#xff08;走同一个wifi模块接入&#xff09;&#xff0c;包含不同网段的ip。 现场是基于三层的无线漫游&#xff0c;多个路由器wifi配置了相同的ssid信息&a…

springBoot静态资源文件夹以及文件夹之间的优先级

1、springBoot静态资源文件夹&#xff0c;系统默认路径&#xff0c;优先级由大到小 classpath:/META-INF/resources/ classpath:/resources/ classpath:/static/ classpath:/public/ 比如当static文件夹中和public文件夹中都存在a.html 浏览器访问localhost:8080/a.html将访问…

ref和reactive

看尤雨溪说&#xff1a;为什么Vue3 中应该使用 Ref 而不是 Reactive&#xff1f;

pintia6-2符号函数 6-1两点距离

pintia的函数题&#xff0c;只需要把函数写上去就可以了&#xff0c;6-2函数题比较简单&#xff0c;三个if就可以解决: 6-1则套用数学公式即可&#xff0c;注意把函数名复制粘贴过去&#xff0c;以免抄错

网络加速工具

注册之后, 下载软件, 可免费试用4小时. 亲测可用, 网速还是很不错的 点击以下官网地址进行注册 https://tgjkdjfk.top/a.php?alavBTtF8UWAySC 或者 https://doveee.com/aff.php?alavBTtF8UWAySC 注册登录之后的个人中心 电脑端安装之后的界面如下 电脑端(macOS Windows)和手…

Django的web框架Django Rest_Framework精讲(二)

文章目录 1.自定义校验功能&#xff08;1&#xff09;validators&#xff08;2&#xff09;局部钩子&#xff1a;单字段校验&#xff08;3&#xff09;全局钩子&#xff1a;多字段校验 2.raise_exception 参数3.context参数4.反序列化校验后保存&#xff0c;新增和更新数据&…

起心动念 | 生成式 AI 开发实践系列的开端

生成式 AI 和大模型的技术变革力量&#xff0c;正在逐渐影响着我们当下这个时代&#xff0c;全球各行各业都呈现百舸争流、万象更新的趋势。在 2023 年&#xff0c;我们通过各种面向开发者的活动&#xff0c;收集到了大量开发者关于基于生成式 AI 的开发内容需求和建议反馈。开…

Boosting semantic human matting with coarse annotations

前向推理在modelscope中开源了&#xff0c;但是训练没开源&#xff0c;且是基于TensorFlow的&#xff0c;复现起来是比较麻烦的。 1.Introduction 分割技术主要集中在像素级二元分类&#xff0c;抠图被建模为前景图像F和背景图像B的加权融合&#xff0c;大多数matte方法采用指…

HiSilicon352 android9.0 开机视频调试分析

一&#xff0c;开机视频概念 开机广告是在系统开机后实现播放视频功能。 海思Android解决方案在原生Android基础上&#xff0c;增加了开机视频模块&#xff0c;可在开机过程中播放视频文件&#xff0c;使用户更好的体验系统开机过程。 二&#xff0c;模块结构 1. 海思自研开机…

Linux 高并发服务器

多进程并发服务器 使用多进程并发服务器时要考虑以下几点&#xff1a; 父进程最大文件描述个数(父进程中需要close关闭accept返回的新文件描述符)系统内创建进程个数(与内存大小相关)进程创建过多是否降低整体服务性能(进程调度) server /* server.c */ #include <stdio…

IDEA反编译Jar包

反编译步骤 使用IDEA安装decompiler插件 找到decompiler插件文件夹所在位置&#xff08;IDEA安装路径/plugins/java-decompiler/lib &#xff09;&#xff0c;将需要反编译的jar包放到decompiler插件文件夹下&#xff0c;并创建一个空的文件夹&#xff0c;用来存放反编译后的…

电子信息考博目标院校

电子信息考博 1.目标院校 第一志愿 武汉大学 211计算机学院(2024年度) 085400电子信息 新一代信息通信技术&#xff08;卓工博士专项&#xff09; 外语水平考试科目 1101英语 卓工博士专项计划详见专项简章 212电子信息学院(2024年度) 085400电子信息 新一代信息通信…

AJAX-常用请求方法和数据提交

常用请求方法 请求方法&#xff1a;对服务器资源&#xff0c;要执行的操作 axios请求配置 url&#xff1a;请求的URL网址 method&#xff1a;请求的方法&#xff0c;如果是GET可以省略&#xff1b;不用区分大小写 data&#xff1a;提交数据 axios({url:目标资源地址,method…

【C语言】异常处理 | assert函数 | errno错误码

文章目录 C语言传统的处理错误的方式1. 终止程序&#xff08;例如使用 assert&#xff09;2. 返回/设置错误码手动实现C语言库函数内置的错误码Linux系统调用内置的错误码 C语言传统的处理错误的方式 C语言传统的处理错误的方式主要包括assert终止程序和返回或设置错误码两种方…

Django的web框架Django Rest_Framework精讲(三)

文章目录 1.DRF视图1) 视图基类1.GET请求2.POST请求&#xff0c;添加单条记录3.更新单条记录put方法4.DELETE请求 2) GenericAPIView[通用视图类] 2.视图类中使用多个序列化器类的方法3.基于视图扩展类的视图接口1&#xff09;ListModelMixin2&#xff09;CreateModelMixin3&am…

如何远程操控vm虚拟机(finalshell版)

你是否因为虚拟机命令行操作不便而头疼&#xff1f;是否因为难以复制粘贴而烦恼&#xff1f;是否因为无法快速上传文件而烦躁&#xff1f; 别急&#xff01;现在有一个简单便捷的软件能够实现上述你所述说的所有烦恼&#xff0c;请听我细细道来~ 一、查看虚拟机的ip地址 a.首…

python-分享篇-GUI界面开发-PyQt5-窗体代码与逻辑代码分离

代码 # _*_ coding:utf-8 _*_ # 文件名称&#xff1a;LoginWindows.py # 开发工具&#xff1a;PyCharmimport sys # 导入操作系统模块from PyQt5.QtCore import QCoreApplication # 导入PyQt5的QtCore模块 from PyQt5.QtWidgets import QApplication,QMainWindow # 导入P…

【game——关机程序】

程序运行后&#xff0c;会在1分钟内关机&#xff0c;用户需要输入&#xff1a;lalala&#xff0c;才能停止电脑关机。 电脑内有操作命令符&#xff0c;可以实现关机&#xff1a; 最后按一下回车&#xff1a; #include<stdio.h> #include<stdlib.h> #include<s…

分类预测 | Matlab实现GAF-PCNN-MATT格拉姆角场和双通道PCNN融合多头注意力机制的分类预测/故障识别

分类预测 | Matlab实现GAF-PCNN-MATT格拉姆角场和双通道PCNN融合多头注意力机制的分类预测/故障识别 目录 分类预测 | Matlab实现GAF-PCNN-MATT格拉姆角场和双通道PCNN融合多头注意力机制的分类预测/故障识别分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现G…

【Crypto | CTF】BUUCTF Alice与Bob1

天命&#xff1a;比较简单的题目 先用Python生成一个脚本&#xff0c;分解两个素数 def prime_factors(n):"""分解给定整数n的质因数。返回一个列表&#xff0c;其中包含n的所有质因数。"""# 初始化一个空列表来存储质因数factors []# 从2开始…