詳解Angular2中的編程對象Observable
前言
RxJs提供的核心是Observable對象,它是一個使用可觀察數(shù)據(jù)序列實現(xiàn)組合異步和事件編程。
跟這個很類似的異步編程模型是Promise,Promise是基于狀態(tài)變化的異步模型,一旦由等待狀態(tài)進入成功或失敗狀態(tài)便不能再次修改,當狀態(tài)變化時訂閱者只能夠拿到一個值;而Observable是基于序列的異步編程模型,隨著序列的變化,訂閱者可以持續(xù)不斷的獲取新的值。而且Promise只提供回話機制,并沒有更多的操作來支持對結(jié)果的復(fù)雜處理,而Observable提供了多種多樣的操作符,來處理運算結(jié)果,以滿足復(fù)雜的應(yīng)用邏輯。
在實際編程中,我們主要與三個對象打交道:Observable、observer、Subscription:
以一個元素的click事件為例看看如何使用Observable:
var clickStream = new Rx.Observable(observer => { var handle = evt => observer.next(evt); element.addEventListener('click', handle); return () => element.removeEventListener('click', handle); }); subscription = clickStream.subscribe(evt => { console.log('onNext: ' + evt.id); }, err => { console.error('onError'); }, () => { console.log('onComplete'); }); setTimeout(() => { subscription.unsubscribe(); }, 1000);
如果每個事件都需要這么包裝一下,豈不是太麻煩了,所以RxJs為我們提供了一個便利函數(shù):Observable.fromEvent
來方便的銜接事件。
常見的鏈接操作符:concat、merge、combineLates等
投影操作:map、flatMap,flatMap需要重點介紹
過濾:filter、distinctUltilChanges、
操作符分類:Operators by Categories
錯誤處理:catch、retry、finally
減壓:debounce、throttle、sample、pausable
減少:buffer、bufferWithCount、bufferWithTime
想要掌握Observable的操作符先要學(xué)會看懂序列圖:
箭頭代表著隨時間變化的序列,比如在一個元素上不斷點擊鼠標,圓圈代表序列對外產(chǎn)生的影響,如每一次點擊元素都會觸發(fā)一次事件回調(diào),圓圈中的數(shù)字是對外發(fā)射的信息,如每一次事件的觸發(fā)都會有一個事件對象,代表本次操作的一些信息。
想要靈活的運用Observable處理復(fù)雜的邏輯,就要學(xué)會使用它提供的操作符。我將操作符分為兩類,單序列操作和復(fù)合序列操作,單序列操作是指的針對一個序列進行的操作運算,復(fù)合序列操作指的是對兩個或者多個序列進行處理的操作符,復(fù)合序列操作相對更難懂一些。
下面先看單序列操作,以map操作為例:
map操作是將一個序列中每次對外發(fā)射的信息做轉(zhuǎn)換,如上圖map將每次的發(fā)射值乘以十,那么當訂閱者訂閱之后每次得到的訂閱值就不再是原始的123而是經(jīng)過轉(zhuǎn)換后的10 20 30。通過序列圖能更方便的理解Observable的運算。
下面我們來看一個復(fù)合序列操作,以merge為例
merge操作的目的是將兩個獨立序列,合成一個序列。原本序列1隨著時間的前進,在100ms時發(fā)射a,在200ms時發(fā)射b,300ms時發(fā)射c,它的訂閱者在400ms將受到abc三個值;序列2在150ms時發(fā)射d,250ms時發(fā)射e,350ms時發(fā)射f,它的訂閱者在400ms內(nèi)收到def三個值。而merge之后的新序列將在400ms內(nèi)收到abcdef(注意順序)。
常用操作符的理解:
Observable.range:發(fā)射一定數(shù)量值得序列。
Observable.toArray: 在序列完成時將所有發(fā)射值轉(zhuǎn)換為一個數(shù)組。
Observable.flatMap: 將原始序列流中的元素轉(zhuǎn)化為一個新的序列流,并將這個新的序列流merge到原來的序列中元素的位置。
Observable.startWith: 它會設(shè)置Observable序列的第一個值
Observable.combineLatest: 類似于promiseAll,在所有序列有結(jié)果后才會執(zhí)行
Observable.scan: 將序列中每次發(fā)射的值可以做聚合,與reduce類似,reduce會將整個序列的值聚合起來,在序列完成時發(fā)送一個最終值
Observable.sample: 從持續(xù)的序列中取得一定的樣品
Observable.merge:將多個序列合并成一個,可以做OR來使用
Observable.timestamp: 能夠得到每個發(fā)射值的發(fā)射時的時間
Observable.distinctUntilChanged(compare, selector): selector取出用來比較的key,compare用來比較兩個key
Observable.takeWhile() 當參數(shù)為false時停止發(fā)射數(shù)據(jù)
總結(jié)
以上就是這篇文章的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
Angular2學(xué)習(xí)教程之組件中的DOM操作詳解
這篇文章主要給大家介紹了Angular2學(xué)習(xí)教程之組件中DOM操作的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來看看吧。2017-05-05AngularJS使用Filter自定義過濾器控制ng-repeat去除重復(fù)功能示例
這篇文章主要介紹了AngularJS使用Filter自定義過濾器控制ng-repeat去除重復(fù)功能,結(jié)合實例形式分析了AngularJS自定義過濾器的定義及數(shù)組過濾相關(guān)操作技巧,需要的朋友可以參考下2018-04-04angular 服務(wù)的單例模式(依賴注入模式下)詳解
這篇文章主要介紹了angular 服務(wù)的單例模式(依賴注入模式下)詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10- 每個Angular版本在其生命周期中都經(jīng)歷了各個階段。組件在Angular中起著關(guān)鍵作用; 在這里,本文將討論Angular中的組件生命周期以及它們?nèi)绾斡绊懣蚣芩邪姹镜纳芷凇?/div> 2021-05-05
angular json對象push到數(shù)組中的方法
下面小編就為大家分享一篇angular json對象push到數(shù)組中的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02Angular.js實現(xiàn)動態(tài)加載組件詳解
這篇文章主要給大家介紹了關(guān)于Angular.js實現(xiàn)動態(tài)加載組件的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-05-05最新評論