摘要:實例化一個對象向接受者發(fā)送一個消息流接受者訂閱消息,獲取消息流中的數(shù)據(jù)接受者訂閱消息,獲取消息流中的數(shù)據(jù)這樣兩路接受者都能拿到發(fā)送的數(shù)據(jù)流是的一個衍生類,它將數(shù)據(jù)流中的最新值推送給接受者。
Rxjs_Subject 及其衍生類
在 RxJS 中,Observable 有一些特殊的類,在消息通信中使用比較頻繁,下面主要介紹較常用的幾個類:
1/ SubjectSubject 可以實現(xiàn)一個消息向多個訂閱者推送消息。
Subject 是一種特殊類型的 Observable,它允許將值多播給多個觀察者,所以 Subject 是多播的,而普通的 Observables 是單播的(每個已訂閱的觀察者都擁有 Observable 的獨立執(zhí)行)。每個 Subject 都是觀察者。 - Subject 是一個有如下方法的對象: next(v)、error(e) 和 complete() 。要給 Subject 提供新值,只要調(diào)用 next(theValue),它會將值多播給已注冊監(jiān)聽該 Subject 的觀察者們。
var subject = new Rx.Subject(); //實例化一個Subject對象 subject.next(1); //向接受者發(fā)送一個消息流 subject.subscribe({ next: value => console.log("observerA: " + value) //接受者A訂閱消息,獲取消息流中的數(shù)據(jù) }); subject.subscribe({ next: value => console.log("observerB: " + value) //接受者B訂閱消息,獲取消息流中的數(shù)據(jù) });
這樣兩路接受者都能拿到發(fā)送的數(shù)據(jù)流:
observerA:1 observerB:12/ BehaviorSubject
BehaviorSubject 是 Subject 的一個衍生類,它將數(shù)據(jù)流中的最新值推送給接受者。
var subject = new Rx.BehaviorSubject(0); //聲明一個 BehaviorSubject 對象 subject.next(1); //發(fā)送一個數(shù)據(jù)流 subject.next(2); //再發(fā)送一個數(shù)據(jù)流 subject.subscribe({ next: v => console.log("observerA: " + v) //接受者 A 訂閱消息 }); subject.subscribe({ next: v => console.log("observerB: " + v) //接受者 B 訂閱消息 }); subject.next(3); //再發(fā)送一個數(shù)據(jù)流
這樣,每次接受者只會接受最新最送的那個消息:
observerA:2 observerB:2 observerA:3 observerB:33/ ReplaySubject
ReplaySubject 類似于 BehaviorSubject,它可以發(fā)送舊值給新的訂閱者,但它還可以記錄 Observable 執(zhí)行的一部分。
當(dāng)創(chuàng)建 ReplaySubject 時,你可以指定回放多少個值:
var subject = new Rx.ReplaySubject(3); // 為新的訂閱者緩沖3個值 subject.subscribe({ next: v => console.log("observerA: " + v) }); subject.next(1); subject.next(2); subject.next(3); subject.next(4); subject.subscribe({ next: v => console.log("observerB: " + v) }); subject.next(5);
輸出:
observerA: 1 observerA: 2 observerA: 3 observerA: 4 observerB: 2 observerB: 3 observerB: 4 observerA: 5 observerB: 54/ AsyncSubject
AsyncSubject 是另一個 Subject 變體,只有當(dāng) Observable 執(zhí)行完成時(執(zhí)行 complete()),它才會將執(zhí)行的最后一個值發(fā)送給觀察者。
var subject = new Rx.AsyncSubject(); subject.subscribe({ next: v => console.log("observerA: " + v) }); subject.next(1); subject.next(2); subject.next(3); subject.next(4); subject.subscribe({ next: v => console.log("observerB: " + v) }); subject.next(5); subject.complete();
輸出:
observerA: 5 observerB: 5
參考文檔《PublishSubject,ReplaySubject,BehaviorSubject,AsyncSubject》
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/101471.html
摘要:返回的對象同時是類型的,擁有方法。由于調(diào)用后,開始執(zhí)行,因此,會返回一個供調(diào)用者來終止執(zhí)行。是的一個衍生類,具有最新的值的概念。舉一個形象的例子,表示一個人的生日,而則表示一個人的歲數(shù)。 什么是Subject? 在RxJS中,Subject是一類特殊的Observable,它可以向多個Observer多路推送數(shù)值。普通的Observable并不具備多路推送的能力(每一個Observer...
摘要:隨著前端應(yīng)用的復(fù)雜度越來越高,如何管理應(yīng)用的數(shù)據(jù)已經(jīng)是一個不可回避的問題。應(yīng)用的數(shù)據(jù)不是只有狀態(tài)的,還有事件異步常量等等。出于以上兩點原因,最終決定基于來設(shè)計一套管理應(yīng)用的狀態(tài)的解決方案。 隨著前端應(yīng)用的復(fù)雜度越來越高,如何管理應(yīng)用的數(shù)據(jù)已經(jīng)是一個不可回避的問題。當(dāng)你面對的是業(yè)務(wù)場景復(fù)雜、需求變動頻繁、各種應(yīng)用數(shù)據(jù)互相關(guān)聯(lián)依賴的大型前端應(yīng)用時,你會如何去管理應(yīng)用的狀態(tài)數(shù)據(jù)呢? 我們認為...
摘要:前言新增了兩種基本的原生數(shù)據(jù)集合和加上和現(xiàn)在共有四種,以及由兩者衍生出的弱引用集合和。其本身是生成實例數(shù)據(jù)集合的構(gòu)造函數(shù),可以接受一個數(shù)組或具有接口的數(shù)據(jù)結(jié)構(gòu)作為參數(shù)用來初始化。返回鍵值對的遍歷器對象,鍵值對為鍵名鍵值。 前言 ES6新增了兩種基本的原生數(shù)據(jù)集合:Set和Map(加上Array和Object現(xiàn)在共有四種),以及由兩者衍生出的弱引用集合:WeakSet和WeakMap。從...
摘要:舉例來說,每年都有生日是一道數(shù)據(jù)流,但是一個人的年齡卻是一個流。運行結(jié)果顯示,第二個在訂閱之后,獲得了數(shù)據(jù)流中最后毫秒事件內(nèi)產(chǎn)生的和三個值。 原文:http://reactivex.io/rxjs/manu... Subject是什么? RxJS的Subject是Observable的一個特殊類型,他可以將流中的值廣播給眾多觀察者(Observer)。一般的Observalbe流是單一...
閱讀 1994·2021-09-23 11:21
閱讀 1773·2019-08-29 17:27
閱讀 1131·2019-08-29 17:03
閱讀 808·2019-08-29 15:07
閱讀 2015·2019-08-29 11:13
閱讀 2455·2019-08-26 12:14
閱讀 1056·2019-08-26 11:52
閱讀 1794·2019-08-23 17:09