① , 首先引入npm
import { Observable } from 'rxjs';
② , 使用setTimeOut來模擬延遲 , 返回Observable對象句柄異步
var stream : Observable<string> = new Observable( observer => { setTimeout( () : void => { observer.next("okokok"); } , 2000 ); });
③ , 經過Observable對象句柄 , 獲取異步數據ide
stream.subscribe( (value : string) => { console.log( value ); } );
④ , 結果this
意思 : 在異步還沒執行前 , 撤銷行動
引入 :code
import { Subscription } from 'rxjs';
① , 接收Subscription句柄server
var sub : Subscription = this._stream.subscribe( (value : string) => { console.log( value ); } );
② , 使用Subscription句柄調用unsubscribe(),撤銷行動對象
setTimeout( () : void => { //取消執行 sub.unsubscribe(); } , 1500 );
這樣 , 由於在1.5S就執行了撤銷 , 因此行動在2S後觸發是不會執行的 , 因此不會打印 "okokok"blog
將setOutTime改爲setIntervalrxjs
var stream : Observable<string> = new Observable( observer => { setInterval( () : void => { observer.next("okokok"); } , 2000 ); });
結果:ip
注意 : Angular 6以前請執行命令 npm install rxjs-compat
① , 引入
import {map,filter} from 'rxjs/operators';
② , 構建異步
var count : number = 0; var stream : Observable<number> = new Observable( observer => { setInterval( () : void => { count ++; observer.next(count); } , 2000 ); });
③ , 訂閱改變以下
stream.pipe( filter( value => value % 2 === 0 ) , map( value => { return Math.pow( value , 2 ); } ) ).subscribe( value => { console.log( value ); } );
能夠看出 , 在訂閱以前加了一層處理放在pipe中
④ , 結果