91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Flutter?StreamBuilder怎么實現局部刷新

發布時間:2022-08-24 15:53:06 來源:億速云 閱讀:173 作者:iii 欄目:開發技術

這篇文章主要講解了“Flutter StreamBuilder怎么實現局部刷新”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Flutter StreamBuilder怎么實現局部刷新”吧!

前言

在flutter項目中,頁面內直接調用setState方法會使得頁面重新執行build方法,導致內部組件被全量刷新,造成不必要的性能消耗。出于性能和用戶體驗方面的考慮我們經常會使用局部刷新代替全量刷新進行頁面更新的操作。

包括ProviderValueNotifierStatefulBuilder等在內的技術方案,都能夠幫助我們實現Flutter局部刷新的需求。

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工具我們可以捕獲到組件刷新的情況如下,整個頁面被重新構建,這種情況下性能消耗較大。

Flutter?StreamBuilder怎么實現局部刷新

點擊第二個ElevatedButton按鈕后,頁面執行streamController.add(a)方法,通過系統的Flutter Performance工具我們可以捕獲到組件刷新的情況如下,只有StreamBuilder組件及其內部組件被重新構建,實現了局部刷新的功能,有效的提高了頁面的性能。

Flutter?StreamBuilder怎么實現局部刷新

感謝各位的閱讀,以上就是“Flutter StreamBuilder怎么實現局部刷新”的內容了,經過本文的學習后,相信大家對Flutter StreamBuilder怎么實現局部刷新這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳山县| 玛曲县| 阿拉善右旗| 广河县| 汕尾市| 长泰县| 高阳县| 寻甸| 荔浦县| 元氏县| 闽侯县| 铜川市| 扶余县| 兰坪| 南宫市| 修武县| 桂阳县| 永善县| 广元市| 朝阳县| 邳州市| 固始县| 嘉鱼县| 陆河县| 腾冲县| 新乡市| 慈溪市| 承德市| 卓尼县| 文登市| 娱乐| 南漳县| 河东区| 洛扎县| 太和县| 台中县| 洪湖市| 高邑县| 永修县| 雷山县| 江源县|