亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

flutter Bloc 更新后事件同步與異步詳解

 更新時間:2022年11月14日 15:36:31   作者:李小轟_Rex  
這篇文章主要為大家介紹了flutter Bloc 更新后事件同步與異步詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

前言

最近,小轟參與了公司 flutter 項目關于 Dart 2.0 的空安全升級工作。我們升級了所有依賴的三方庫,其中就包括有 Bloc 庫。作為一款使用率頗高的狀態(tài)管理框架, Bloc 在版本迭代中進行了少許結構和細節(jié)的優(yōu)化,下面是小轟對于 Bloc 新版本的使用總結。

使用方式

小轟使用的 Bloc 版本如下

flutter_bloc: ^7.3.1

通過最簡單的例子來學習新知識

  • 創(chuàng)建一個包含 操作的頁面,使用 bloc 來操作 自增 自減 事件。
class _TestBlocPageState extends State<TestBlocPage> {
  late TestDartBloc _bloc;
  @override
  void initState() {
    super.initState();
    _bloc = TestDartBloc(TestDartState(0));
  }
  @override
  Widget build(BuildContext context) {
    return BlocBuilder<TestDartBloc, TestDartState>(
      bloc: _bloc,
      builder: (context, state) {
        return Column(
          children: [
            //顯示當前的數字結果
            Text(state.num.toString()),
            TextButton(
                onPressed: () {
                  //進行自增操作
                  _bloc.add(IncreaseEvent());
                },
                child: Text('add')),
            TextButton(
                onPressed: () {
                  //進行自減操作
                  _bloc.add(ReduceEvent());
                },
                child: Text('reduce')),
          ],
        );
      },
    );
  }
}

Blocstateevent 模型定義如下

part of 'test_dart_bloc.dart';
/// Bloc state
class TestDartState {
  int num = 0;
  TestDartState(this.num);
}
part of 'test_dart_bloc.dart';
/// Bloc event
@immutable
abstract class TestDartEvent {}
//自增事件
class IncreaseEvent extends TestDartEvent{}
//自減事件
class ReduceEvent extends TestDartEvent{}

創(chuàng)建 Bloc ,重寫 mapEventToState 接收事件流轉狀態(tài)流

import 'dart:async';
import 'package:flutter_bloc/flutter_bloc.dart';
part 'test_dart_event.dart';
part 'test_dart_state.dart';
class TestDartBloc extends Bloc<TestDartEvent, TestDartState> {
  TestDartBloc(TestDartState state) : super(state);
  @override
  Stream<TestDartState> mapEventToState(TestDartEvent event) async* {
    if (event is IncreaseEvent) {
      await Future.delayed(Duration(seconds: 10));
      yield TestDartState(state.num + 1);
    } else if (event is ReduceEvent) {
      yield TestDartState(state.num - 1);
    }
  }
}

好了,直接運行如上代碼,我們的demo就能完整的跑起來。但,以上的寫法和低版本的 Bloc 完全一致,在經歷高版本迭代后,Bloc 到底做了哪些優(yōu)化呢?

Bloc 新形態(tài)用法

小轟在源碼里看到,重寫 mapEventToState 的使用方式已經被棄用了,會在將來的某個版本中徹底刪除該 API

  /// **@Deprecated - Use on<Event> instead. Will be removed in v8.0.0**
  ///
  /// Must be implemented when a class extends [Bloc].
  /// [mapEventToState] is called whenever an [event] is [add]ed
  /// and is responsible for converting that [event] into a new [state].
  /// [mapEventToState] can `yield` zero, one, or multiple states for an event.
  @Deprecated('Use on<Event> instead. Will be removed in v8.0.0')
  Stream<State> mapEventToState(Event event) async* {}

新用法推薦使用 on 來進行事件注冊,我們將上面demo中的 bloc 進行寫法改造:

class TestDartBloc extends Bloc<TestDartEvent, TestDartState> {
  TestDartBloc(TestDartState state) : super(state) {
    init();
  }
  void init() {
    on<IncreaseEvent>((event, emit) async {
      await Future.delayed(Duration(seconds: 10));
      emit(TestDartState(state.num + 1));
    });
    on<ReduceEvent>((event, emit) {
      state.num - 1;
      emit(state);
    });
  }
}

替換代碼后運行demo,直接成功。

事件隊列的阻塞屬性?

目前最新版本的 Bloc 同時支持 onmapEventToState 兩種寫法,那么這兩種寫法有實際區(qū)別嗎?

小轟在使用老版本(空安全之前)bloc 時總結過一篇文章 聊聊 Bloc event 的隊列屬性

blocmapEventToState 方法中,event 隊列是一個阻塞性隊列,先進先出,只有當上一個事件消費完畢后,才會響應隊列中的下一個事件。

如上demo( mapEventToState 方式): 自增事件中模擬耗時了10s,當依次點擊 自增自減 按鈕后,由于事件隊列的阻塞特性,自增事件消費10秒后,自減事件才會被 mapEventToState 響應。

那么,這個特性在 bloc 迭代新版本后還存在嗎?在最新版本的bloc中,小轟通過demo測試得出結論:

  • 當使用 mapEventToState 方式進行事件捕獲時,event 隊列 保持 阻塞 特性。
  • 而使用 on 方式進行注冊監(jiān)聽時,event 隊列 默認是異步非阻塞的,是互不干擾的。如果把 bloc 當作事件總線來使用,小轟認為 異步非阻塞 這樣的設計更為合理。

提問:如果想使用 on 的方式進行注冊,還想事件隊列保證順序執(zhí)行即保持阻塞特性,應該怎么辦呢? 解答:使用 自定義 transformer,這樣就實現(xiàn)了事件同步隊列。

    on<IncreaseEvent>((event, emit) async {
      await Future.delayed(Duration(seconds: 10));
      emit(TestDartState(state.num + 1));
    },
    transformer: (events, mapper) => events.asyncExpand(mapper),
);

參考鏈接: pub.dev/packages/bl…

以上就是flutter Bloc 更新后事件同步與異步詳解的詳細內容,更多關于flutter Bloc 更新事件同步異步的資料請關注腳本之家其它相關文章!

相關文章

  • Apache?Cordova?Android原理應用實例詳解

    Apache?Cordova?Android原理應用實例詳解

    這篇文章主要為大家介紹了Apache?Cordova?Android原理應用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • Android 實現(xiàn)滑動的六種方式

    Android 實現(xiàn)滑動的六種方式

    這篇文章主要給大家分享的是Android 實現(xiàn)滑動的六種方式,分別是layout、scrollBy、offsetLeftAndRight offsetTopAndButton、LayoutParams、Scroller、平移動畫,需要的朋友可以參考一下下面文章的具體內容
    2021-11-11
  • Android實現(xiàn)EditText控件禁止輸入內容的方法(附測試demo)

    Android實現(xiàn)EditText控件禁止輸入內容的方法(附測試demo)

    這篇文章主要介紹了Android實現(xiàn)EditText控件禁止輸入內容的方法,涉及Android針對EditText控件屬性設置的相關技巧,需要的朋友可以參考下
    2015-12-12
  • 詳解Gradle構建過程

    詳解Gradle構建過程

    Gradle是項目構建工具,是Google官方推薦的Android項目編譯工具。構建工具是可以讓開發(fā)者以可執(zhí)行和有序的任務來表達自動化的需求。就是將源代碼生成可執(zhí)行程序。本文將詳細介紹Gradle構建過程
    2021-06-06
  • Android開發(fā)之自帶下載器DownloadManager的使用示例代碼

    Android開發(fā)之自帶下載器DownloadManager的使用示例代碼

    本篇文章主要介紹了Android開發(fā)之自帶下載器DownloadManager的使用示例代碼,Android自帶的DownloadManager是一個很好的下載文件的工具,有興趣的可以了解一下。
    2017-03-03
  • Android SurfaceView基礎用法詳解

    Android SurfaceView基礎用法詳解

    這篇文章主要介紹了Android SurfaceView基礎用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • Android 選擇相冊照片并返回功能的實現(xiàn)代碼

    Android 選擇相冊照片并返回功能的實現(xiàn)代碼

    這篇文章主要介紹了Android 從相冊中選擇照片并返回功能,需要的朋友可以參考下
    2018-03-03
  • Android中ListView的幾種常見的優(yōu)化方法總結

    Android中ListView的幾種常見的優(yōu)化方法總結

    Android中的ListView應該算是布局中幾種最常用的組件之一,本篇文章主要做了三種優(yōu)化總結,有興趣的可以了解一下。
    2017-02-02
  • Android onActivityResult和setResult方法詳解及使用

    Android onActivityResult和setResult方法詳解及使用

    這篇文章主要介紹了Android onActivityResult和setResult方法詳解及使用的相關資料,這里提供實例,幫助大家學習理解,需要的朋友可以參考下
    2016-12-12
  • Android實現(xiàn)透明動畫

    Android實現(xiàn)透明動畫

    這篇文章主要為大家詳細介紹了Android實現(xiàn)透明動畫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05

最新評論