• [RxJS] AsyncSubject: representing a computation that yields a final value


    This lesson will teach you about AsyncSubject, another type of Subject with some replaying logic inside. We will also look at some use cases for this peculiar RxJS subject variant.

    AsyncSubject:

    Emit last value only when sequence completed. 

    BehaviorSubject:

    Replay onces, only before compleation.

    ReplaySubject:

    Replay many, before of after compleation.

    var subject = new Rx.AsyncSubject();
    
    // Subject
    // ReplaySubject: replays many, before or after completion
    // BehaviorSubject: replays one, only before completion
    // AsyncSubject: replays one, only if completed
    
    var observerA = {
      next: function (x) { console.log('A next ' + x); },
      error: function (err) { console.log('A error ' + err); },
      complete: function () { console.log('A done'); },
    };
    
    subject.subscribe(observerA);
    console.log('observerA subscribed');
    
    var observerB = {
      next: function (x) { console.log('B next ' + x); },
      error: function (err) { console.log('B error ' + err); },
      complete: function () { console.log('B done'); },
    };
    
    setTimeout(() => subject.next(1), 100);
    setTimeout(() => subject.next(2), 200);
    setTimeout(() => subject.next(3), 300);
    setTimeout(() => subject.complete(), 350);
    
    /*
    ----1---2---3--|       
      .............3|
                       3|
    */
    
    setTimeout(function () {
      subject.subscribe(observerB);
      console.log('observerB subscribed');
    }, 400);
    /*
    "observerA subscribed"
    "A next 3"
    "A done"
    "B next 3"
    "B done"
    "observerB subscribed"
    */
  • 相关阅读:
    SQL Server 配置管理器不见了
    SQL常用函数使用
    数据库优化
    关于百度地图js api的getCurrentPosition定位不准确的解决方法
    uni-app中使用外部字体
    不定高度,元素垂直居中
    css实现的鼠标悬浮提示
    导入
    下载
    百度地图在地图上标点显示数字
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5977464.html
Copyright © 2020-2023  润新知