温馨提示×

温馨提示×

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

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

Angular之Rxjs基础操作

发布时间:2020-08-05 19:44:07 来源:网络 阅读:824 作者:Aonaufly 栏目:开发技术

一 : 处理异步 (Observable)

① , 首先引入

import { Observable } from 'rxjs';

② , 使用setTimeOut来模拟延迟 , 返回Observable对象句柄

var stream : Observable<string> = new Observable( observer => {
        setTimeout( () : void => {
          observer.next("okokok");
        } , 2000 );
      });

③ , 通过Observable对象句柄 , 获取异步数据

stream.subscribe( (value : string) => {
        console.log( value );
      } );

④ , 结果
Angular之Rxjs基础操作

二 : 取消订阅(承上一操作)

意思 : 在异步还没执行前 , 撤销行动
引入 :

import { Subscription } from 'rxjs';

① , 接收Subscription句柄

var sub : Subscription = this._stream.subscribe( (value : string) => {
        console.log( value );
      } );

② , 使用Subscription句柄调用unsubscribe(),撤销行动

        setTimeout( () : void => {
          //取消执行
          sub.unsubscribe();
        } , 1500 );

这样 , 因为在1.5S就执行了撤销 , 所以行动在2S后触发是不会执行的 , 所以不会打印 "okokok"

三 : 订阅的多次执行(承上一操作) , 注意不要撤销动作

将setOutTime改成setInterval

var stream : Observable<string> = new Observable( observer => {
        setInterval( () : void => {
          observer.next("okokok");
        } , 2000 );
      });

结果:
Angular之Rxjs基础操作

四 : 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基础操作

向AI问一下细节

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

AI