Angular之Rxjs基礎操做

一 : 處理異步 (Observable)

① , 首先引入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 );
      } );

④ , 結果
Angular之Rxjs基礎操做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 );
      });

結果:
Angular之Rxjs基礎操做ip

四 : filter , map (承上三操做) 可是將傳值改成number類型

注意 : 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中

④ , 結果
Angular之Rxjs基礎操做

相關文章
相關標籤/搜索