網站首頁 編程語言 正文
前言
在flutter項目中,頁面內直接調用setState
方法會使得頁面重新執行build
方法,導致內部組件被全量刷新,造成不必要的性能消耗。出于性能和用戶體驗方面的考慮我們經常會使用局部刷新代替全量刷新進行頁面更新的操作。
包括Provider
、ValueNotifier
和StatefulBuilder
等在內的技術方案,都能夠幫助我們實現Flutter局部刷新的需求。有興趣了解StatefulBuilder
局部刷新方法可以點擊《Flutter StatefulBuilder 實現局部刷新》進行查看,本文記錄的是通過StreamBuilder
來實現局部刷新的方法。
StreamBuilder 簡介
StreamBuilder
組件的源代碼如下,其中包含了四個參數:
const StreamBuilder({ Key? key, this.initialData, Stream<T>? stream, required this.builder, }) : assert(builder != null), super(key: key, stream: stream);
key : 組件的鍵值
initialData : 初始值數據,用于確保第一幀有可用數據顯示,否則將使用 null 值構建第一幀
stream : 用于監聽自己創建的數據流
builder : 必傳參數,返回一個小部件用于頁面構建
其中builder
包含了兩個參數,一個頁面的context,另一個是當前快照信息:
typedef AsyncWidgetBuilder<T> = Widget Function(BuildContext context, AsyncSnapshot<T> snapshot); final AsyncWidgetBuilder<T> builder;
StreamBuilder的實際應用
StreamBuilder
組件在實際應用中主要分成以下操作:
1、聲明一個StreamController
類型的控制器;
2、將需要局部刷新數據的組件嵌套在StreamBuilder
組件內,接收信息;
3、往StreamBuilder
里添加數據,并通知StreamBuilder
重新構建;
4、關流,避免內存泄漏。
int a = 0; // 1、聲明一個StreamController類型的控制器,命名為streamController; final StreamController<int> streamController = StreamController(); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ // 2、將需要局部刷新數據的組件嵌套在StreamBuilder組件內,并接收信息; StreamBuilder<int>( stream: streamController.stream, initialData: a, builder: (BuildContext context, AsyncSnapshot<int> snapshot) { return Text('a : $a'); }, ), ElevatedButton( onPressed: () { a++; setState(() {}); }, child: Text('setState'), ), ElevatedButton( onPressed: () { a++; // 3、往`StreamBuilder`里添加數據,并通知`StreamBuilder`重新構建; streamController.add(a); }, child: Text('streamBuilder'), ), ], ), ), ); } @override void dispose() { // TODO: implement dispose super.dispose(); // 4、關流,避免內存泄漏 streamController.close(); }
點擊第一個ElevatedButton
按鈕后,頁面執行setState(() {})
方法,通過系統的Flutter Performance工具我們可以捕獲到組件刷新的情況如下,整個頁面被重新構建,這種情況下性能消耗較大。
點擊第二個ElevatedButton
按鈕后,頁面執行streamController.add(a)
方法,通過系統的Flutter Performance工具我們可以捕獲到組件刷新的情況如下,只有StreamBuilder
組件及其內部組件被重新構建,實現了局部刷新的功能,有效的提高了頁面的性能。
總結
為了避免State.setState方法重新構建全局造成的性能消耗,我們可以通過StreamBuilder組件對頁面進行局部刷新。
原文鏈接:https://juejin.cn/post/7135027674228998151
相關推薦
- 2023-03-01 多語言切換在Androidx失效的踩坑解決記錄_Android
- 2022-07-03 Golang之空結構體和零長數組的實踐
- 2022-09-24 win2019?ftp服務器搭建圖文教程_FTP服務器
- 2023-10-30 配置阿里的yum源
- 2022-05-04 redis?zset實現滑動窗口限流的代碼_Redis
- 2022-04-15 基于Redis?zSet實現滑動窗口對短信進行防刷限流的問題_Redis
- 2022-07-02 C語言由淺入深理解指針_C 語言
- 2022-06-22 Android實現注冊界面_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支