news 2026/5/1 6:19:23

Flutter 入门实战:构建一个简单的天气应用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flutter 入门实战:构建一个简单的天气应用

标题:Flutter 入门实战:构建一个简单的天气应用

引言

随着移动应用开发需求的不断增长,跨平台框架成为开发者关注的焦点。Flutter 作为 Google 推出的 UI 工具包,凭借高性能、高保真和“一次编写,多端运行”的优势,迅速在开发者社区中崛起。本文将带你从零开始,使用 Flutter 构建一个简单的天气应用,并结合实际代码演示核心概念。


一、环境准备

在开始前,请确保已安装以下工具:

  • Flutter SDK(推荐版本 3.19 或以上)
  • Dart SDK(随 Flutter 自动安装)
  • 编辑器:VS Code 或 Android Studio
  • 模拟器或真机用于调试

创建项目:

flutter create weather_appcdweather_app

二、项目结构概览

Flutter 项目的基本结构如下:

lib/ ├── main.dart # 应用入口 └── screens/ └── weather_screen.dart # 天气页面

我们将在main.dart中启动应用,并在weather_screen.dart中实现主要逻辑。


三、编写代码:实现一个简单天气界面

1.main.dart—— 应用入口
// lib/main.dartimport'package:flutter/material.dart';import'screens/weather_screen.dart';voidmain(){runApp(constMyApp());}classMyAppextendsStatelessWidget{constMyApp({super.key});@overrideWidgetbuild(BuildContext context){returnMaterialApp(title:'天气应用',theme:ThemeData(primarySwatch:Colors.blue,useMaterial3:true,),home:constWeatherScreen(),debugShowCheckedModeBanner:false,// 隐藏右上角 debug 标签);}}
2. 创建天气页面:weather_screen.dart
// lib/screens/weather_screen.dartimport'package:flutter/material.dart';classWeatherScreenextendsStatefulWidget{constWeatherScreen({super.key});@overrideState<WeatherScreen>createState()=>_WeatherScreenState();}class_WeatherScreenStateextendsState<WeatherScreen>{// 模拟天气数据String cityName="北京";int temperature=22;String description="晴朗";// 模拟刷新天气void_refreshWeather(){setState((){// 随机生成温度(15~30°C)temperature=(15+(15*Math.Random().nextDouble())).toInt();// 随机描述finaldescriptions=["晴朗","多云","小雨","阴天","雷阵雨"];description=descriptions[Random().nextInt(descriptions.length)];});}@overrideWidgetbuild(BuildContext context){returnScaffold(appBar:AppBar(title:constText("🌤️ 天气预报"),centerTitle:true,),body:Container(padding:constEdgeInsets.all(20),child:Column(mainAxisAlignment:MainAxisAlignment.center,children:[// 城市名称Text(cityName,style:constTextStyle(fontSize:32,fontWeight:FontWeight.bold),),constSizedBox(height:20),// 温度Text('$temperature°C',style:constTextStyle(fontSize:64,color:Colors.orange),),constSizedBox(height:10),// 天气描述Text(description,style:constTextStyle(fontSize:20,color:Colors.grey),),constSizedBox(height:40),// 刷新按钮ElevatedButton.icon(onPressed:_refreshWeather,icon:constIcon(Icons.refresh),label:constText("更新天气"),style:ElevatedButton.styleFrom(padding:constEdgeInsets.symmetric(horizontal:30,vertical:15),),),],),),);}}

⚠️ 注意:请在文件顶部添加导入:

import'dart:math';

四、运行应用

在项目根目录运行以下命令:

flutter run

你将看到一个简洁美观的天气界面,点击“更新天气”按钮后,温度和天气描述会随机变化,得益于 Flutter 的热重载(Hot Reload),你可以在修改代码后几乎立即看到效果。


五、核心概念解析

  1. Widget 架构
    Flutter 中一切皆为 Widget。Scaffold提供页面骨架,AppBar是顶部栏,Column用于垂直布局。

  2. 状态管理(setState)
    _refreshWeather方法中调用setState(),通知 Flutter 重新构建 UI,实现动态更新。

  3. Material Design 组件
    使用ElevatedButtonText等 Material 风格组件,自动适配 Android 和 iOS 视觉规范。

  4. 布局与间距
    SizedBox用于控制元素间距离,PaddingCenter实现精准排版。


六、扩展建议(进阶方向)

  • ✅ 接入真实 API:使用 OpenWeatherMap API 获取实时天气。
  • ✅ 添加输入框让用户搜索城市。
  • ✅ 使用http包请求网络数据:
    # pubspec.yamldependencies:http:^1.0.0
  • ✅ 引入状态管理方案如ProviderRiverpod管理复杂状态。

七、总结

通过这个简单的天气应用,我们实践了 Flutter 的基本开发流程:

  • 使用 Dart 编写逻辑
  • 通过 Widget 构建 UI
  • 利用setState实现交互响应
  • 快速预览与调试

Flutter 不仅让跨平台开发变得高效,更以出色的性能和灵活的设计赢得了广泛青睐。无论你是初学者还是资深开发者,掌握 Flutter 都将为你打开通往现代多端应用开发的大门。


🚀 下一步建议:
尝试将本项目接入真实天气 API,并支持多城市切换,打造属于你的完整跨平台天气 App!

GitHub 示例仓库参考:github.com/example/flutter-weather-app(模拟地址)


本文代码可在 Flutter 3.x 环境下正常运行,SDK 支持 Android、iOS 与 Web 平台。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 4:45:35

dom 相关api getBoundingClientRect

getBoundingClientRect() 是 JavaScript 中一个非常重要的 DOM API&#xff0c;用于获取元素在视口&#xff08;viewport&#xff09;中的位置和尺寸信息。const rect element.getBoundingClientRect();返回一个 DOMRect 对象&#xff0c;包含以下只读属性&#xff08;单位&am…

作者头像 李华
网站建设 2026/5/1 4:44:11

收藏!裁员潮下程序员破局:AI大模型是你的高薪“救生圈”

当下的程序员圈&#xff0c;早已不是“敲码就能稳坐钓鱼台”的时代&#xff0c;职业焦虑正以肉眼可见的速度蔓延。 就在前几天&#xff0c;某TOP3互联网大厂的技术主管在闭门交流群里抛出的消息&#xff0c;让不少人脊背发凉&#xff1a;年底优化已正式启动&#xff01;公司AI大…

作者头像 李华
网站建设 2026/5/1 4:51:22

# 【深度好文】一文读懂知识图谱:9大关键技术全解析(建议收藏)

知识图谱是揭示实体间关系的语义网络&#xff0c;构建包含九大核心技术&#xff1a;知识抽取(获取知识单元)、实体与关系抽取(识别实体及关系)、属性抽取(收集实体属性)、实体对齐(解决实体冲突)、知识表示(如RDF三元组)、知识融合(整合多源知识)、知识更新(数据与模式层更新)以…

作者头像 李华
网站建设 2026/4/25 5:22:06

Claude Skills全攻略:AI代理的“超能力“,让大模型为你打工

Claude 现已引入 Skills 功能&#xff0c;显著提升了其执行特定任务的能力。Skills 本质上是一个包含指令、脚本和资源的结构化文件夹&#xff0c;Claude 能够根据任务需求动态加载这些资源。 这一机制的核心优势在于按需加载&#xff1a;Claude 仅在检测到当前任务与特定技能相…

作者头像 李华
网站建设 2026/4/22 4:25:27

Linux相关基础

VMware1.下载所需软件&#xff0c;个人学习使用VMware&#xff0c;这里需要注意&#xff0c;下载vmware成功&#xff0c;会在网络里面产生如下图俩个网络&#xff0c;VMnet1对应仅主机模式使用&#xff0c;VMet8个人创建虚拟机时候使用&#xff0c;对应NAT模式。下载好之和&…

作者头像 李华