Flutter之FutureBuilder的使用

FutureBuilder 是 Flutter 中用于构建基于 Future 返回的最新计算快照(Snapshot)的 Widget。使用 FutureBuilder 可以非常方便地根据异步计算的结果来创建 UI。

基本使用

FutureBuilder 主要有两个属性:

  • future:我们要监听的 Future
  • builder:一个返回 Widget 的回调函数。这个函数的参数包括 BuildContextAsyncSnapshot,其中 AsyncSnapshot 包含了 Future 的计算结果。

使用步骤

  1. 定义一个 Future 函数

    这个函数通常用来进行一些异步操作,比如网络请求。

    dart 复制代码
    Future<String> fetchData() async {
      await Future.delayed(Duration(seconds: 2)); // 模拟网络延迟
      return "Data fetched";
    }
  2. 使用 FutureBuilder

    将定义的 Future 函数与 FutureBuilder 一起使用,根据其执行的结果构建 UI。

    dart 复制代码
    FutureBuilder<String>(
      future: fetchData(),
      builder: (BuildContext context, AsyncSnapshot<String> snapshot) {
        // 判断 Future 是否执行结束
        if (snapshot.connectionState == ConnectionState.waiting) {
          return CircularProgressIndicator(); // 返回一个加载指示器
        } else {
          if (snapshot.hasError) {
            return Text('Error: ${snapshot.error}');
          } else {
            return Text('Data: ${snapshot.data}'); // 返回获取的数据
          }
        }
      },
    )

示例代码

下面是一个完整的简单示例,使用 FutureBuilder 显示从 Future 获取的数据。

dart 复制代码
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: Text('FutureBuilder Example')),
        body: MyFutureBuilder(),
      ),
    );
  }
}

class MyFutureBuilder extends StatelessWidget {
  // 定义一个 Future 函数来模拟获取数据的操作
  Future<String> fetchData() async {
    await Future.delayed(Duration(seconds: 2)); // 模拟网络延迟
    return "Data fetched";
  }

  @override
  Widget build(BuildContext context) {
    return Center(
      child: FutureBuilder<String>(
        future: fetchData(),
        builder: (BuildContext context, AsyncSnapshot<String> snapshot) {
          // 根据 snapshot 的状态返回不同的 Widget
          if (snapshot.connectionState == ConnectionState.waiting) {
            return CircularProgressIndicator(); // 如果 Future 还在运行,返回一个进度指示器
          } else {
            if (snapshot.hasError) {
              return Text('Error: ${snapshot.error}');
            } else {
              return Text('Data: ${snapshot.data}'); // 如果 Future 完成且无错误返回数据
            }
          }
        },
      ),
    );
  }
}

注意事项

  • FutureBuilderbuilder 方法可能会被多次调用,尤其是在 Future 函数执行的过程中,它可能会调用多次 builder 来重建 UI。
  • 避免直接在 FutureBuilderfuture 属性中创建 Future 实例。如果这样做,每次 build 方法执行时,都会创建一个新的 Future 实例,导致不必要的计算。通常将 Future 实例定义为 State 对象的成员变量或者使用 FutureBuilder 的静态构造方法 FutureBuilder.value
相关推荐
Rhys..13 分钟前
webdriveragent setup教程
ios
GISer_Jing29 分钟前
2026年前端AI开发终极指南
前端·人工智能
攀登的牵牛花32 分钟前
2026年最危险的,不是不会写代码,而是不会设计 Agent 工作流
前端·agent
LanceJiang37 分钟前
设计模式在前端的简易实现与作用
前端·设计模式
代码煮茶43 分钟前
Vue3 虚拟列表实战 | 解决长列表性能问题(十万条数据流畅渲染,附原理)
前端·javascript·vue.js
雨季mo浅忆1 小时前
前端如何实现长连接之使用WebSocket长连接
前端·websocket
We་ct1 小时前
LeetCode 201. 数字范围按位与:位运算高效解题指南
开发语言·前端·javascript·算法·leetcode·typescript
Patrick_Wilson1 小时前
你的 MR 超过 500 行了吗?——大型代码合并请求拆分实战指南
前端·代码规范·前端工程化
神三元1 小时前
大模型工具调用输出的 JSON,凭什么能保证不出错?
前端·ai编程
得物技术1 小时前
基于 Cursor Agent 的流水线 AI CR 实践|得物技术
前端·程序员·全栈