zoukankan      html  css  js  c++  java
  • [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"
    */
  • 相关阅读:
    VTK二维图像的三维显示
    VtkTransform 和 SetPosition的区别
    Qt QList 遍历元素
    Qt QList详解
    QT QList介绍及应用
    Qt 生成随机区间浮点数 generateRand
    Qt qsrand qrand 产生随机数的两只方法
    Qt QStringLiteral
    Qt QMap简单用法
    Qt 遍历QMap
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5977464.html
Copyright © 2011-2022 走看看