博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Angular之Rxjs基础操作
阅读量:6278 次
发布时间:2019-06-22

本文共 1644 字,大约阅读时间需要 5 分钟。

一 : 处理异步 (Observable)

① , 首先引入

import { Observable } from 'rxjs';

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

var stream : Observable
= 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
= 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
= 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基础操作

转载于:https://blog.51cto.com/aonaufly/2405013

你可能感兴趣的文章
svn eclipse unable to load default svn client的解决办法
查看>>
Android.mk 文件语法详解
查看>>
QT liunx 工具下载
查看>>
内核源码树
查看>>
Java 5 特性 Instrumentation 实践
查看>>
AppScan使用
查看>>
Java NIO框架Netty教程(三) 字符串消息收发(转)
查看>>
Ucenter 会员同步登录通讯原理
查看>>
php--------获取当前时间、时间戳
查看>>
Spring MVC中文文档翻译发布
查看>>
docker centos环境部署tomcat
查看>>
JavaScript 基础(九): 条件 语句
查看>>
Linux系统固定IP配置
查看>>
配置Quartz
查看>>
Linux 线程实现机制分析
查看>>
继承自ActionBarActivity的activity的activity theme问题
查看>>
设计模式01:简单工厂模式
查看>>
项目经理笔记一
查看>>
Hibernate一对一外键双向关联
查看>>
mac pro 入手,php环境配置总结
查看>>