news 2026/4/18 8:02:15

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/4/18 7:42:55

Java运算中的类型转换

Java运算中的类型转换分为两类&#xff1a;隐式转换&#xff08;自动类型提升&#xff09;和强制类型转换。隐式类型转换主要由两条规则&#xff1a;取值范围小的和取值范围大的进行运算&#xff0c;小的会先提升为大的&#xff0c;再进行运算&#xff1b;byte、short、char三种…

作者头像 李华
网站建设 2026/4/8 23:27:17

想搞永磁同步电机控制又不想烧板子?联合仿真了解一下。最近拿Maxwell和Simplorer折腾了一套SVPWM控制方案,实测电流环响应速度比外卖小哥抢单还快

Maxwell和Simplorer联合仿真——永磁同步电机SVPWM控制 本仿真用AnsysEM实现永磁同步电机&#xff08;PMSM&#xff09;的仿真模拟&#xff0c;控制方式采用空间矢量控制&#xff0c;闭环方式采用电流环速度环双闭环控制。 文件中包含一个仿真文件&#xff0c;以及仿真搭建的简…

作者头像 李华
网站建设 2026/4/18 2:18:41

无线电能传输仿真模型:S-S拓扑结构及主电路参数设计

无线电能传输仿真模型&#xff0c;电路采用S-S拓扑结构。 闭环输出电压400v&#xff0c;输出效果良好。 采用的是移相控制。 另有主电路的参数设计过程。深夜两点盯着示波器屏幕&#xff0c;突然发现谐振电流的波形开始优雅地跳起华尔兹——这是我在调试S-S型无线电能传输系统时…

作者头像 李华
网站建设 2026/4/18 4:32:10

vue基于Springboot框架的在线导游预约系统

目录已开发项目效果实现截图开发技术系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&…

作者头像 李华
网站建设 2026/4/18 4:21:57

别躺平!为什么说12 月秋招捡漏黄金期?

哈喽各位同学&#xff01;眼看 2025 年只剩最后一个月&#xff0c;不少小伙伴觉得秋招早就结束了&#xff0c;开始摆烂等春招&#xff1f;但作为过来人&#xff0c;玖玖学长必须跟你们说&#xff1a;12 月才是海归弯道超车的好机会&#xff0c;秋招捡漏黄金期可千万别错过&…

作者头像 李华
网站建设 2026/4/17 3:09:17

基于微信小程序的宠物领养系统的设计与实现论文

摘要本文主要在宠物领养系统设计和实现过程中&#xff0c;利用微信小程序开发技术、SpringBoot框架和MySQL数据库搭建一个功能和使用方便的宠物品种收养互联网系统&#xff0c;该系统包含了普通用户和管理员两种种身份用户&#xff0c;其具备了诸多功能供用户选择。对于普通用户…

作者头像 李华