Flutter?StreamBuilder實(shí)現(xiàn)局部刷新實(shí)例詳解
前言
在flutter項(xiàng)目中,頁面內(nèi)直接調(diào)用setState
方法會(huì)使得頁面重新執(zhí)行build
方法,導(dǎo)致內(nèi)部組件被全量刷新,造成不必要的性能消耗。出于性能和用戶體驗(yàn)方面的考慮我們經(jīng)常會(huì)使用局部刷新代替全量刷新進(jìn)行頁面更新的操作。
包括Provider
、ValueNotifier
和StatefulBuilder
等在內(nèi)的技術(shù)方案,都能夠幫助我們實(shí)現(xiàn)Flutter局部刷新的需求。有興趣了解StatefulBuilder
局部刷新方法可以點(diǎn)擊《Flutter StatefulBuilder 實(shí)現(xiàn)局部刷新》進(jìn)行查看,本文記錄的是通過StreamBuilder
來實(shí)現(xiàn)局部刷新的方法。
StreamBuilder 簡介
StreamBuilder
組件的源代碼如下,其中包含了四個(gè)參數(shù):
const StreamBuilder({ Key? key, this.initialData, Stream<T>? stream, required this.builder, }) : assert(builder != null), super(key: key, stream: stream);
key : 組件的鍵值
initialData : 初始值數(shù)據(jù),用于確保第一幀有可用數(shù)據(jù)顯示,否則將使用 null 值構(gòu)建第一幀
stream : 用于監(jiān)聽自己創(chuàng)建的數(shù)據(jù)流
builder : 必傳參數(shù),返回一個(gè)小部件用于頁面構(gòu)建
其中builder
包含了兩個(gè)參數(shù),一個(gè)頁面的context,另一個(gè)是當(dāng)前快照信息:
typedef AsyncWidgetBuilder<T> = Widget Function(BuildContext context, AsyncSnapshot<T> snapshot); final AsyncWidgetBuilder<T> builder;
StreamBuilder的實(shí)際應(yīng)用
StreamBuilder
組件在實(shí)際應(yīng)用中主要分成以下操作:
1、聲明一個(gè)StreamController
類型的控制器;
2、將需要局部刷新數(shù)據(jù)的組件嵌套在StreamBuilder
組件內(nèi),接收信息;
3、往StreamBuilder
里添加數(shù)據(jù),并通知StreamBuilder
重新構(gòu)建;
4、關(guān)流,避免內(nèi)存泄漏。
int a = 0; // 1、聲明一個(gè)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、將需要局部刷新數(shù)據(jù)的組件嵌套在StreamBuilder組件內(nèi),并接收信息; 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`里添加數(shù)據(jù),并通知`StreamBuilder`重新構(gòu)建; streamController.add(a); }, child: Text('streamBuilder'), ), ], ), ), ); } @override void dispose() { // TODO: implement dispose super.dispose(); // 4、關(guān)流,避免內(nèi)存泄漏 streamController.close(); }
點(diǎn)擊第一個(gè)ElevatedButton
按鈕后,頁面執(zhí)行setState(() {})
方法,通過系統(tǒng)的Flutter Performance工具我們可以捕獲到組件刷新的情況如下,整個(gè)頁面被重新構(gòu)建,這種情況下性能消耗較大。
點(diǎn)擊第二個(gè)ElevatedButton
按鈕后,頁面執(zhí)行streamController.add(a)
方法,通過系統(tǒng)的Flutter Performance工具我們可以捕獲到組件刷新的情況如下,只有StreamBuilder
組件及其內(nèi)部組件被重新構(gòu)建,實(shí)現(xiàn)了局部刷新的功能,有效的提高了頁面的性能。
總結(jié)
為了避免State.setState方法重新構(gòu)建全局造成的性能消耗,我們可以通過StreamBuilder組件對頁面進(jìn)行局部刷新。
以上就是Flutter StreamBuilder實(shí)現(xiàn)局部刷新實(shí)例詳解的詳細(xì)內(nèi)容,更多關(guān)于Flutter StreamBuilder局部刷新的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android studio 項(xiàng)目手動(dòng)在本地磁盤中刪除module后,殘留文件夾無法刪除的問題解決方法
這篇文章主要介紹了Android studio 項(xiàng)目手動(dòng)在本地磁盤中刪除module后,殘留文件夾無法刪除問題,本文給出了解決方法,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03Android OkHttp Post上傳文件并且攜帶參數(shù)實(shí)例詳解
這篇文章主要介紹了Android OkHttp Post上傳文件并且攜帶參數(shù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03Kotlin 使用Lambda來設(shè)置回調(diào)的操作
這篇文章主要介紹了Kotlin 使用Lambda來設(shè)置回調(diào)的操作方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Android用tabhost實(shí)現(xiàn) 界面切換,每個(gè)界面為一個(gè)獨(dú)立的activity操作
這篇文章主要介紹了Android用tabhost實(shí)現(xiàn) 界面切換,每個(gè)界面為一個(gè)獨(dú)立的activity操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09Android Studio實(shí)現(xiàn)仿微信APP門戶界面詳解及源碼
這篇文章帶你通過Android studio來實(shí)現(xiàn)微信APP的門戶界面,主要說明框架的各部分功能與實(shí)現(xiàn)過程,下文包含了整個(gè)開發(fā)過程,以及解決問題的思路并再末尾提供了源碼鏈接2021-10-10Android適配安卓6.0藍(lán)牙通訊實(shí)現(xiàn)過程
這篇文章主要為大家詳細(xì)介紹了Android適配安卓6.0藍(lán)牙通訊實(shí)現(xiàn)過程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09Android實(shí)現(xiàn)簡單實(shí)用的垂直進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡單實(shí)用的垂直進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07Android實(shí)現(xiàn)炫酷的CheckBox效果
大家是不是對系統(tǒng)自帶的CheckBox產(chǎn)生乏味感了呢?今天這篇文章給大家?guī)淼氖且豢钊碌腃heckBox,下面來一起看看下面的CheckBox吧!有需要的朋友們可以參考借鑒。2016-10-10Android Studio實(shí)現(xiàn)幀動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了Android Studio實(shí)現(xiàn)幀動(dòng)畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Recyclerview添加頭布局和尾布局、item點(diǎn)擊事件詳解
這篇文章主要為大家詳細(xì)介紹了Recyclerview添加頭布局和尾布局、item點(diǎn)擊事件的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08