Skip to content

Flutter 简介

Flutter 是什么

Flutter 是 Google 推出的开源 UI 工具包,用于构建跨平台、高性能的应用程序。它允许开发者使用单一代码库为移动、Web、桌面和嵌入式设备创建美观的原生应用。

Flutter 的核心概念

1. Widget

在 Flutter 中,一切都是 Widget。Widget 是构建 UI 的基本单位,它可以是一个按钮、一个文本、一个容器,甚至是整个应用。

Flutter 提供了丰富的内置 Widget,如:

  • Text - 显示文本
  • Container - 容器,可设置宽高、颜色等
  • Row/Column - 水平/垂直布局
  • Stack - 层叠布局
  • ListView - 列表
  • GridView - 网格

2. 状态管理

Flutter 应用的状态管理是开发中的重要部分,常见的状态管理方案有:

  • setState - 简单状态管理
  • Provider - 轻量级状态管理
  • Bloc - 基于流的状态管理
  • Riverpod - 新一代状态管理库
  • GetX - 全功能状态管理库

3. 热重载

Flutter 的热重载功能允许开发者在不重启应用的情况下查看代码更改的效果,大大提高了开发效率。

4. 平台特定代码

Flutter 允许开发者通过平台通道调用原生代码,实现平台特定的功能。

Flutter 架构

Flutter 采用分层架构,从上到下依次是:

  1. Framework 层 - 提供高级 API,如 Widgets、手势、动画等
  2. Engine 层 - 由 C++ 实现,负责渲染、动画、原生交互等
  3. Embedder 层 - 负责将 Flutter 嵌入到不同平台

Flutter 与其他框架的比较

Flutter vs React Native

  • Flutter 使用 Dart 语言,React Native 使用 JavaScript/TypeScript
  • Flutter 有自己的渲染引擎,React Native 使用原生组件
  • Flutter 提供热重载,React Native 提供热更新
  • Flutter 的 UI 一致性更好,React Native 更接近原生体验

Flutter vs 原生开发

  • Flutter 开发效率更高,一套代码多平台运行
  • 原生开发性能可能略高,但 Flutter 性能已足够优秀
  • Flutter 学习曲线相对较平缓
  • 原生开发对平台特定功能的支持更直接

适用场景

Flutter 适合以下场景:

  • 需要快速开发的跨平台应用
  • 对 UI 要求较高的应用
  • 预算有限但需要多平台支持的项目
  • 原型设计和快速迭代的项目

基于 VitePress 的本地知识库