Flutter學習筆記(31)--非同步更新UI

来源:https://www.cnblogs.com/upwgh/archive/2020/06/12/13100886.html
-Advertisement-
Play Games

大家都知道,子線程不能操作UI控制項,在我們Android的日常開發中,經常會遇到網路請求數據通過線程間通信,將數據發送到UI線程中去更新UI,在Flutter中是如何處理非同步更新UI的呢? 今天我們介紹一下FutureBuilder。 ...


如需轉載,請註明出處:Flutter學習筆記(31)--非同步更新UI

大家都知道,子線程不能操作UI控制項,在我們Android的日常開發中,經常會遇到網路請求數據通過線程間通信,將數據發送到UI線程中去更新UI,在Flutter中是如何處理非同步更新UI的呢?

今天我們介紹一下FutureBuilder。

  const FutureBuilder({
    Key key,
    this.future,
    this.initialData,
    @required this.builder,
  })

構造參數說明:

feture:接收一個Future對象,用於處理耗時操作。

initialData:預設數據。

builder:widget構建器,會在future的不同階段多次調用。構建器簽名如下:

Widget Function(BuildContext context, AsyncSnapshot<T> snapshot);

模擬一個網路請求數據回來後更新UI的場景,先看下整體的示例

import 'dart:async';

import 'package:flutter/material.dart';

class FutureBuilderDemo extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return new _FutureBuilderDemoState();
  }
}

class _FutureBuilderDemoState extends State {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'FutureBuilderDemo',
      home: new Scaffold(
        appBar: AppBar(
          title: new Text('FutureBuilderDemo'),
        ),
        body: new Center(
          child: FutureBuilder<String>(
            future: mockNetworkData(),
            initialData: '我是預設的數據',
            builder: (BuildContext context, AsyncSnapshot snapshot) {
              if (snapshot.hasError) {
                return new Text('erro');
              } else {
                return new Text(snapshot.data);
              }
            },
          ),
        ),
      ),
    );
  }

  Future<String> mockNetworkData() async {
    return Future.delayed(Duration(seconds: 11), () => '我是網路請求的數據');
  }
}

 snapshot:會包含當前非同步任務的狀態信息及結果信息 ,比如我們可以通過snapshot.connectionState獲取非同步任務的狀態信息、通過snapshot.hasError判斷非同步任務是否有錯誤等等

       

以上就是今天下拉刷新和上拉載入的全部內容了,如果有錯誤的地方或者有任何疑問,歡迎留言!!!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、MongoDB用戶認證機制簡介 為了認證客戶端,你必須要添加一個對應的用戶到MongoDB。基本的步驟分為以下幾步: 用戶管理介面:db.createUser()方法可以創建一個用戶,添加完成後可以分配角色給用戶,第一個用戶必須是管理員,用來管理其他用戶。你也可以更新存在的用戶,必須修改密碼和權 ...
  • 第一步:開啟郵箱功能 -開啟發郵件功能 exec sp_configure 'show advanced options',1 –顯示為1時,代表功能開啟 reconfigure with override go exec sp_configure 'database mail xps',1 –顯示 ...
  • 所有知識體系文章,GitHub已收錄,歡迎老闆們前來Star! GitHub地址: https://github.com/Ziphtracks/JavaLearningmanual MySQL觸發器 一、什麼是觸發器 觸發器(trigger)是MySQL提供給程式員和數據分析員來保證數據完整性的一種 ...
  • redis交叉編譯 平臺: Windows: x86 x86_64 Linux: arm aarch64 armv8l 倉庫地址: https://github.com/huskar-t/redis 成品地址 github 藍奏 編譯過程 有需要過程的底下留言 ...
  • 數據存儲和有效期 在 redis 工作流程中,過期的數據並不需要馬上就要執行刪除操作。因為這些刪不刪除只是一種狀態表示,可以非同步的去處理,在不忙的時候去把這些不緊急的刪除操作做了,從而保證 redis 的高效 數據的存儲 在redis中數據的存儲不僅僅需要保存數據本身還要保存數據的生命周期,也就是過 ...
  • 1.啟動oracle埠監聽 lsnrctl start 2.啟動資料庫 sqlplus / as sysdba 回車 開啟資料庫:startup 關閉監聽 lsnrctl stop 關閉資料庫服務 shutdown ...
  • 一、findViewById函數和Toast類 (1)Button button1 = (Button) findViewById(R.id.button_1); 通過findViewById方法,去佈局中找出R.id.button_1名稱的Button按鈕,這個方法會返回一個View對象,然後進行 ...
  • 原文在這裡 作者簡介:Jose,剛大學畢業,現帶領團隊負責維護Flutter的Material庫, Material是一個幫助團隊建設高質量用戶體驗的設計體系。 假設你的ui里有一個widget,並且您希望在該widget的頂部覆蓋一個浮動widget。 可能該widget被旋轉或應用了其他轉換,如 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...