使用 Rx 中预定义的 Subject

发布时间:2020-07-21 03:26:58 作者:张涛泽
来源:网络 阅读:300

看到一幅有趣的关于 Rx 学习的图,想知道学习 Rx 的学习曲线?不,是峭壁!

使用 Rx 中预定义的 Subject

我们可以直接通过 Rx 的 Observer 来创建 Observable 对象。

但是,使用这种方式往往比较复杂,在特定的场景下,我们可以直接使用 Rx 提供的特定 Subject 来实现 Observable。这些特定的 Subject 是主题和订阅者的混合体,我们可以直接使用这样的一个对象来实现信息的发布和数据流的订阅。

1. Subject

通用的 Subject,既可以被订阅,从名字也可以看到它本身就是一个主题,所以可以直接用来发布信息。如果需要实现一个普通的主题,它就是最理想的选择。

使用方式:

发布信息的方法:

onNext( value )

发布一个新的值到数据流中。

onCompleted()

数据流终止。

onError( error )

发布异常。

使用示例:

使用 Rx 中预定义的 Subject

var subject = new Rx.Subject();var subscription = subject.subscribe(    function (x) {
        console.log('Next: ' + x.toString());
    },    function (err) {
        console.log('Error: ' + err);
    },    function () {
        console.log('Completed');
    });

subject.next(42);// => Next: 42subject.next(56);// => Next: 56subject.completed();// => Completed

使用 Rx 中预定义的 Subject

 

See Also: 

https://github.com/Reactive-Extensions/RxJS/blob/master/doc/api/subjects/subject.md

2. AsyncSubject

缓存直到 completed() 的最后一个值。所有的订阅者都会收到同样的最后一个值。

注意只能有一个值,在 completed() 之后,将不能再发布新的值。而所有的订阅者也只能得到最后一个值。

使用方式:

必须使用 completed() 完成流,订阅者将会在 completed() 之后才能得到最后一个值。

使用示例:

使用 Rx 中预定义的 Subject

var subject = new Rx.AsyncSubject();var i = 0;var handle = setInterval(function () {
    subject.onNext(i);    if (++i > 3) {
        subject.onCompleted();
        clearInterval(handle);
    }
}, 500);var subscription = subject.subscribe(    function (x) {
        console.log('Next: ' + x.toString());
    },    function (err) {
        console.log('Error: ' + err);
    },    function () {
        console.log('Completed');
    });// => Next: 3// => Completed

使用 Rx 中预定义的 Subject

图例

See also: https://github.com/Reactive-Extensions/RxJS/blob/master/doc/api/subjects/asyncsubject.md

3. BehaviorSubject

如果是希望订阅者获得当前的最后一个值,但是后面可能还会提供新的值,可以考虑这个。

缓存已经发布的最后数据,新的订阅者可以接收到最后一个已经发布的值,和以后发布的新的值。

它可以直接设置一个初始值。如果不需要初始值,可以考虑使用 ReplaySubject.

使用方式:

BehaviorSubject(initialValue)

在构造函数中提供初始的值。

getValue()

获取当前的值,或者抛出异常,在调用了 completed() 之后,最后的值被保留。在 error() 之后,总是抛出一个特定的异常。

使用示例

使用 Rx 中预定义的 Subject

/* Initialize with initial value of 42 */var subject = new Rx.BehaviorSubject(42);var subscription = subject.subscribe(    function (x) {
        console.log('Next: ' + x.toString());
    },    function (err) {
        console.log('Error: ' + err);
    },    function () {
        console.log('Completed');
    });// => Next: 42subject.next(56);// => Next: 56subject.completed();// => Completed

使用 Rx 中预定义的 Subject

图例

 

See also: 

https://github.com/Reactive-Extensions/RxJS/blob/master/doc/api/subjects/behaviorsubject.md

4. ReplaySubject

可以用来缓存流中最后 n 个数据,在新的观察者登记之后,这些缓存的数据直接发布给新的观察者。

使用说明:

在构造 ReplaySubject 对象的时候,配置缓存的数据元素数量以及时间窗口。

ReplaySubject([bufferSize], [windowSize], [scheduler])

使用特定的缓存大小,时间窗口和调度器来创建 ReplaySubject 对象实例.

Arguments
  1. [bufferSize = Number.MAX_VALUE] (Number): Maximum element count of the replay buffer.

  2. [windowSize = NUMBER.MAX_VALUE] (Number): Maximum time length of the replay buffer.

  3. [scheduler = Rx.Scheduler.currentThread] (Scheduler): Scheduler the observers are invoked on.

使用示例

使用 Rx 中预定义的 Subject

var subject = new Rx.ReplaySubject(2 /* buffer size */);

subject.next('a');
subject.next('b');
subject.next('c');var subscription = subject.subscribe(    function (x) {
        console.log('Next: ' + x.toString());
    },    function (err) {
        console.log('Error: ' + err);
    },    function () {
        console.log('Completed');
    });// => Next: b// => Next: csubject.next('d');// => Next: d

使用 Rx 中预定义的 Subject


推荐阅读:
  1. 如何使用xlst将xml转换html
  2. 如何使用javascript中的观察者模式

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

数据流 function 混合体

上一篇:MySQL 5.7 密码策略

下一篇:WSFC基础知识奠基

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》