当前位置: 首页 > news >正文

Flutter入门指南

文章目录

    • 一、环境搭建
    • 二、基本概念
    • 三、创建一个简单的Flutter应用
    • 四、常用组件及代码示例
    • 五、总结
    • 推荐阅读

笔者项目中使用Flutter的模块并不多。虽然笔者还没有机会在项目中正式使用Flutter,但是也在学习Flutter的一些基本用法。本文就是一篇Flutter的入门介绍,后续会写更多深入介绍的文章。Flutter可以通过一套代码库快速构建高质量、高性能的跨平台应用,支持iOS、Android、Web以及桌面平台。在本文中,我们将介绍如何入门Flutter,包括环境搭建、基本概念、常用组件以及示例代码。

一、环境搭建

首先,我们需要搭建Flutter的开发环境。以下是简要的步骤:

  1. 下载并安装Flutter SDK:访问官方网站下载适合你的操作系统的Flutter SDK,并按照官方文档的说明进行安装。

  2. 配置环境变量:将Flutter SDK的bin目录添加到系统的PATH环境变量中。

  3. 安装Android Studio:访问Android Studio官方网站下载并安装Android Studio。在安装过程中,请确保安装Flutter和Dart插件。

  4. 配置iOS开发环境(可选):如果你打算开发iOS应用,需要在macOS上安装Xcode,并配置相关的环境。

  5. 验证环境搭建:在命令行中运行flutter doctor,确保所有组件都已正确安装。

二、基本概念

在开始编写Flutter应用之前,我们需要了解一些基本概念:

  1. Widgets:Flutter中的一切都是Widget(部件)。Widget是构建UI的基本元素,例如文本、按钮、布局等。Flutter提供了丰富的预定义Widget,同时也支持自定义Widget。

  2. StatelessWidget:不可变的Widget,用于展示静态内容。当需要构建不依赖状态变化的UI时,可以使用StatelessWidget。

  3. StatefulWidget:可变的Widget,用于展示动态内容。当需要构建依赖状态变化的UI时,可以使用StatefulWidget。

  4. BuildContext:在Widget树中,BuildContext表示Widget的位置。它是一个关键概念,用于在Widget树中查找数据和传递数据。

三、创建一个简单的Flutter应用

接下来,我们将创建一个简单的Flutter应用,展示一个文本和一个按钮。当点击按钮时,文本内容将发生改变。

  1. 使用flutter create my_app命令创建一个新的Flutter项目。

  2. 打开lib/main.dart文件,删除现有的代码,并添加以下代码:

import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('My First Flutter App')),body: MyHomePage(),),);}
}class MyHomePage extends StatefulWidget {_MyHomePageState createState() => _MyHomePageState();
}class _MyHomePageState extends State<MyHomePage> {String _displayText = 'Hello, Flutter!';void _onButtonPressed() {setState(() {_displayText = 'You have pressed the button!';});}Widget build(BuildContext context) {return Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text(_displayText),RaisedButton(child: Text('Press me'),onPressed: _onButtonPressed,),],),);}
}
  1. 运行应用:在Android Studio中,选择一个模拟器或连接一个真实设备,然后点击运行按钮。你将看到一个包含文本和按钮的简单界面。点击按钮,文本内容将发生改变。

四、常用组件及代码示例

以下是一些在Flutter应用开发中常用的组件及其代码示例:

  1. Containers:Container是一个方便的Widget,它可以将其他Widget包裹起来,并可以应用一些视觉效果,如填充(padding)、边距(margin)、边框(border)、背景颜色等。例如,我们可以在一个Container中显示一个文本:
Container(margin: const EdgeInsets.all(10.0),color: Colors.amber[600],width: 48.0,height: 48.0,child: Center(child: Text('Hello Flutter')),
)
  1. Rows and Columns:Row和Column是两种基本的布局Widget,用于在水平和垂直方向上排列其他Widget。例如,我们可以在一行中排列三个图标:
Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: <Widget>[Icon(Icons.star, color: Colors.red[500]),Icon(Icons.star, color: Colors.red[500]),Icon(Icons.star, color: Colors.red[500]),],
)
  1. Stacks:Stack允许你将多个Widget堆叠在一起,可以用来实现一些复杂的布局效果。例如,我们可以在一个图片上方叠加一个半透明的黑色矩形和一个文本:
Stack(alignment: const Alignment(0.6, 0.6),children: [CircleAvatar(backgroundImage: AssetImage('images/pic.jpg'),radius: 100.0,),Container(decoration: BoxDecoration(color: Colors.black45,),child: Text('Hello Flutter',style: TextStyle(fontSize: 20.0,fontWeight: FontWeight.bold,color: Colors.white,),),),],
)
  1. ListViews:ListView是一个常用的滚动列表Widget,可以用来展示一列可滚动的元素。例如,我们可以创建一个包含三个列表项的ListView:
ListView(children: <Widget>[ListTile(leading: Icon(Icons.map),title: Text('Map'),),ListTile(leading: Icon(Icons.photo),title: Text('Album'),),ListTile(leading: Icon(Icons.phone),title: Text('Phone'),),],
)
  1. Scaffold:Scaffold是一个基本的布局结构,提供了一些常用的页面元素,如app bar、drawer、snack bar、bottom sheet等。例如,我们可以创建一个包含app bar和body的基本页面结构:
Scaffold(appBar: AppBar(title: Text('Hello Flutter'),),body: Center(child: Text('Hello Flutter'),),
)
  1. Buttons:Flutter提供了多种按钮Widget,如RaisedButton、FlatButton、IconButton等。例如,我们可以创建一个RaisedButton,点击时弹出一个SnackBar:
RaisedButton(child: Text('Show a SnackBar'),onPressed: () {Scaffold.of(context).showSnackBar(SnackBar(content: Text('Hello Flutter'),),);},
)
  1. Text and Fonts:Text Widget用于展示文本,你可以通过TextStyle来设置字体、大小、颜色、样式等。例如,我们可以创建一个带样式的文本:
Text('Hello Flutter',style: TextStyle(fontSize: 24.0,fontWeight: FontWeight.w900,color: Colors.blue[700],),
)
  1. Images and Icons:Flutter提供了Image Widget用于展示图片,你可以加载网络图片、本地图片等。同时,Flutter也内置了一套Material Design的图标,可以通过Icon Widget来使用。例如,我们可以创建一个显示网络图片的Image:
Image.network('https://example.com/images/pic.jpg')
  1. Input Widgets:Flutter提供了一些输入Widget,如TextField、Checkbox、Radio、Slider、Switch等。例如,我们可以创建一个文本输入框:
TextField(decoration: InputDecoration(border: OutlineInputBorder(),labelText: 'Enter text here',),
)
  1. Dialogs, Alerts, and Panels:Flutter提供了一些Widget用于展示对话框、警告框、底部面板等,如AlertDialog、SimpleDialog、BottomSheet等。例如,我们可以点击按钮时弹出一个AlertDialog:
RaisedButton(child: Text('Show an alert'),onPressed: () {showDialog(context: context,builder: (BuildContext context) {return AlertDialog(title: Text('Alert'),content: Text('Hello Flutter'),);},);},
)

以上只是一些简单的代码示例,实际上,这些组件可以组合在一起创建更复杂的界面。在实际开发过程中,你会发现Flutter提供的丰富Widget库可以满足各种各样的UI需求。

五、总结

Flutter是一个强大的跨平台UI框架,通过一套代码就可以构建出在多个平台上运行的高质量应用。以上只是Flutter的入门介绍,要想熟练掌握Flutter,还需要不断地学习和实践。希望这篇文章能对你学习Flutter有所帮助。

推荐阅读

Flutter原理与实践

相关文章:

Flutter入门指南

文章目录 一、环境搭建二、基本概念三、创建一个简单的Flutter应用四、常用组件及代码示例五、总结推荐阅读 笔者项目中使用Flutter的模块并不多。虽然笔者还没有机会在项目中正式使用Flutter&#xff0c;但是也在学习Flutter的一些基本用法。本文就是一篇Flutter的入门介绍&am…...

keepalived脑裂问题

脑裂问题产生的原因 就是vip同时存在 master和backup 就叫做脑裂 比如说 backup 机器的防火墙没关&#xff0c;并且没有允许vrrp通过&#xff0c;backup 没有收到master的心跳数据&#xff0c;就会抢夺资源&#xff0c;发生脑裂问题测试 我们打开test3的防火墙&#xff0c;此…...

【Linux笔记】编mysql库

说明当前编译条件&#xff1a;使用cmake 进行编译<当前编译为Ubuntu PC 版本 在虚拟机上面使用> 一、 cmake 库 【 cmake version 3.16.3 】 二、 openssl 库 【 libopenssl-1.1.1K 】 三、mysql 库 【mysql-5.7.36 】 四、boost 库 【boost_1_59_0 】 一、安装cmake 1.1…...

vscode远程免密登录ssh

vscode远程免密登录ssh 1. 安装vscode2. 安装ssh3. 本地vscode配置免密登录远端开发机1. 本地配置秘钥2. 远程开发机配置秘钥 4. vscode常用小工具1. vscode怎么设置ctrl加滚轮放大字体 1. 安装vscode 2. 安装ssh 设置符号打开config配置文件&#xff0c;点击符号ssh连接新的远…...

2024年MathorCup数模竞赛C题详解

C题持续更新中 问题一问题二代码混合ARIMA-LSTM模型构建完整数据与代码第一问第二问 问题一 问题一要求对未来30天每天及每小时的货量进行预测。首先&#xff0c;利用混合ARIMA-LSTM模型进行时间序列预测。ARIMA模型擅长捕捉线性特征和趋势&#xff0c;而LSTM模型处理非线性关…...

【简单讲解如何安装与配置Composer】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…...

深入理解Apache ZooKeeper与Kafka的协同工作原理

目录 引言 一、ZooKeeper基础概念 &#xff08;一&#xff09;ZooKeeper简介 &#xff08;二&#xff09;ZooKeeper数据结构 &#xff08;三&#xff09;ZooKeeper特点 &#xff08;四&#xff09;应用场景 二、ZooKeeper工作模式 &#xff08;一&#xff09;工作机制 …...

js解密心得,记录一次抓包vue解密过程

背景 有个抓包结果被加密了 1、寻找入口&#xff0c;打断点 先正常请求一次&#xff0c;找到需要的请求接口。 寻找入口&#xff0c;需要重点关注几个关键字&#xff1a;new Promise 、new XMLHttpRequest、onreadystatechange、.interceptors.response.use、.interceptors.r…...

redis-哨兵模式

一&#xff0c;哨兵的作用&#xff1a; 通过发送命令&#xff0c;让Redis服务器返回监控其运行状态&#xff0c;包括主服务器和从服务器。当哨兵监测到master宕机&#xff0c;会自动将slave切换成master&#xff0c;然后通过发布订阅模式通知其他的从服务器&#xff0c;修改配…...

自动化测试中的SOLID原则

自动化测试在软件质量保障手段中愈显重要 。但是随着自动化测试代码的规模和复杂性不断扩大&#xff0c;它也很容易出现测试代码重复、紧耦合等问题。而SOLID原则可以解决这一问题&#xff0c;作为自动化用例开发的指导原则。 探索SOLID原则 SOLID原则是一组指导软件开发人员…...

tencentcloud-sdk-python-iotexplorer和tencent-iot-device有什么区别

1. tencent-iot-device tencent-iot-device 是腾讯云提供的物联网设备 SDK&#xff0c;用于在物联网场景中开发和连接设备。这个 SDK 提供了丰富的功能和接口&#xff0c;可以帮助开发者快速构建稳定、高效的物联网应用。 主要功能和特点&#xff1a; 设备连接管理&#xff1…...

Spring day1

day01_eesy_01jdbc pom.xml<packaging>jar</packaging> <dependencies><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --><!--依赖--><dependency><groupId>mysql</groupId><artifactId>mysql-…...

设计模式: 行为型之中介者模式(18)

中介者模式概述 中介者模式&#xff08;Mediator Pattern&#xff09;是一种行为设计模式&#xff0c;它用于减少对象之间的直接交互&#xff0c;从而使其可以松散耦合中介者模式通过引入一个中介者对象来协调多个对象之间的交互&#xff0c;使得这些对象不需要知道彼此的具体…...

计算机网络的起源与发展历程

文章目录 前言时代背景ARPANET 的诞生TCP/IP 协议簇与 Internet 的诞生HTTP 协议与 Web 世界结语 前言 在当今数字化时代&#xff0c;计算机网络已经成为我们生活中不可或缺的一部分。无论是在家庭、学校、还是工作场所&#xff0c;我们都能感受到网络的巨大影响。随着互联网的…...

2024-4-12-实战:商城首页(下)

个人主页&#xff1a;学习前端的小z 个人专栏&#xff1a;HTML5和CSS3悦读 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结&#xff0c;欢迎大家在评论区交流讨论&#xff01; 文章目录 作业小结 作业 .bg-backward {width: 60px; height: 60px;background: url(..…...

一、flask入门和视图

run启动参数 模板渲染 后端给前端页面传参 前端页面设置css from flask import Flask, render_template,jsonify# 创建flask对象 app Flask(__name__)# 视图函数 路由route app.route("/") def hello_world():# 响应&#xff0c;返回给前端的数据return "h…...

Selenium+Chrome Driver 爬取搜狐页面信息

进行selenium包和chromedriver驱动的安装 安装selenium包 在命令行或者anaconda prompt 中输入 pip install Selenium 安装 chromedriver 先查看chrome浏览器的版本 这里是 123.0.6312.106 版 然后在http://npm.taobao.org/mirrors/chromedriver/或者https://googlechrom…...

SpringBoot:一个注解就能帮你下载任意对象

介绍 下载功能应该是比较常见的功能了&#xff0c;虽然一个项目里面可能出现的不多&#xff0c;但是基本上每个项目都会有&#xff0c;而且有些下载功能其实还是比较繁杂的&#xff0c;倒不是难&#xff0c;而是麻烦。 所以结合之前的下载需求&#xff0c;我写了一个库来简化…...

oracle全量、增量备份

采用0221222增量备份策略,7天一个轮回 也就是周日0级备份&#xff0c;周1 2 4 5 6 采用2级增量备份&#xff0c;周3采用1级增量备份 打开控制文件自动备份 CONFIGURE CONTROLFILE AUTOBACKUP ON; 配置控制文件备份路径 CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVI…...

React Router 5 vs 6:使用上的主要差异与升级指南

React Router 5 的一些API 在 React Router 6 上有时可能找不到&#xff0c;可能会看到如下画面&#xff1a;export ‘useHistory’ was not found in ‘react-router-dom’ … React Router目前有两个大的版本&#xff0c;即React Router 5、6。React Router 6 在设计上更加简…...

变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析

一、变量声明设计&#xff1a;let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性&#xff0c;这种设计体现了语言的核心哲学。以下是深度解析&#xff1a; 1.1 设计理念剖析 安全优先原则&#xff1a;默认不可变强制开发者明确声明意图 let x 5; …...

云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?

大家好&#xff0c;欢迎来到《云原生核心技术》系列的第七篇&#xff01; 在上一篇&#xff0c;我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在&#xff0c;我们就像一个拥有了一块崭新数字土地的农场主&#xff0c;是时…...

React Native 导航系统实战(React Navigation)

导航系统实战&#xff08;React Navigation&#xff09; React Navigation 是 React Native 应用中最常用的导航库之一&#xff0c;它提供了多种导航模式&#xff0c;如堆栈导航&#xff08;Stack Navigator&#xff09;、标签导航&#xff08;Tab Navigator&#xff09;和抽屉…...

Python:操作 Excel 折叠

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

第25节 Node.js 断言测试

Node.js的assert模块主要用于编写程序的单元测试时使用&#xff0c;通过断言可以提早发现和排查出错误。 稳定性: 5 - 锁定 这个模块可用于应用的单元测试&#xff0c;通过 require(assert) 可以使用这个模块。 assert.fail(actual, expected, message, operator) 使用参数…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战

“&#x1f916;手搓TuyaAI语音指令 &#x1f60d;秒变表情包大师&#xff0c;让萌系Otto机器人&#x1f525;玩出智能新花样&#xff01;开整&#xff01;” &#x1f916; Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制&#xff08;TuyaAI…...

QT: `long long` 类型转换为 `QString` 2025.6.5

在 Qt 中&#xff0c;将 long long 类型转换为 QString 可以通过以下两种常用方法实现&#xff1a; 方法 1&#xff1a;使用 QString::number() 直接调用 QString 的静态方法 number()&#xff0c;将数值转换为字符串&#xff1a; long long value 1234567890123456789LL; …...

重启Eureka集群中的节点,对已经注册的服务有什么影响

先看答案&#xff0c;如果正确地操作&#xff0c;重启Eureka集群中的节点&#xff0c;对已经注册的服务影响非常小&#xff0c;甚至可以做到无感知。 但如果操作不当&#xff0c;可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

python爬虫——气象数据爬取

一、导入库与全局配置 python 运行 import json import datetime import time import requests from sqlalchemy import create_engine import csv import pandas as pd作用&#xff1a; 引入数据解析、网络请求、时间处理、数据库操作等所需库。requests&#xff1a;发送 …...