let promise = new Promise(resolve => { setTimeout(() => { resolve('---promise timeout---'); }, 2000); }); promise.then(value => console.log(value));
import {Observable} from 'rxjs'; let stream = new Observable(observer => { setTimeout(() => { observer.next('observable timeout'); }, 2000); }); stream.subscribe(value => console.log(value));
从上面列子能够看到 RxJS 和 Promise 的基本用法很是相似,除了一些关键词不一样。Promise 里面用的是 then() 和 resolve(),而 RxJS 里面用的是 next() 和 subscribe()。从上面例子咱们感受Promise 和 RxJS 的用法基本类似。其实Rxjs相比Promise 要强大不少。 好比 Rxjs 中能够中途撤回、Rxjs 能够发射多个值、Rxjs 提供了多种工具函数等等。npm
Promise 的建立以后,动做是没法撤回的。Observable 不同,动做能够经过 unsbscribe() 方 法中途撤回,并且 Observable 在内部作了智能的处理。promise
Promise 建立以后动做没法撤回bash
let promise = new Promise(resolve => { setTimeout(() => { resolve('---promise timeout---'); }, 2000); }); promise.then(value => console.log(value));
Rxjs 能够经过 unsubscribe() 能够撤回 subscribe 的动做异步
let stream = new Observable(observer => { let timeout = setTimeout(() => { clearTimeout(timeout); observer.next('observable timeout'); }, 2000); }); let disposable = stream.subscribe(value => console.log(value)); setTimeout(() => { //取消执行 disposable.unsubscribe(); }, 1000);
若是咱们想让异步里面的方法屡次执行,好比下面代码。函数
这一点 Promise 是作不到的,对于 Promise 来讲,最终结果要么 resole(兑现)、要么 reject (拒绝),并且都只能触发一次。若是在同一个 Promise 对象上屡次调用 resolve 方法, 则会抛异常。而 Observable 不同,它能够不断地触发下一个值,就像 next() 这个方法的 名字所暗示的那样。工具
let promise = new Promise(resolve => { setInterval(() => { resolve('---promise setInterval---'); }, 2000); }); promise.then(value => console.log(value));
Rxjsspa
et stream = new Observable<number>(observer => { let count = 0; setInterval(() => { observer.next(count++); }, 1000); }); stream.subscribe(value => console.log("Observable>"+value));
注意:Angular6 之后使用之前的 rxjs 方法,必须安装 rxjs-compat 模块才可使用 map、filter 方法。code
angular6 后官方使用的是 RXJS6 的新特性,因此官方给出了一个能够暂时延缓咱们不须要修 改 rsjx 代码的办法。server
npm install rxjs-compat
et stream= new Observable<any>(observer => { let count = 0; setInterval(() => { observer.next(count++); }, 1000); }); stream.filter(val=>val%2==0) .subscribe(value => console.log("filter>"+value)); stream .map(value => { return value * value }) .subscribe(value => console.log("map>"+value));
Rxjs 的变化参考文档:http://bbs.itying.com/topic/5bfce189b110d80f905ae545对象
RXJS6 改变了包的结构,主要变化在 import 方式和 operator 上面以及使用 pipe()
import {Observable} from 'rxjs';
import {map,filter} from 'rxjs/operators';
let stream= new Observable<any>(observer => { let count = 0; setInterval(() => { observer.next(count++); }, 1000); }); stream.pipe( filter(val=>val%2==0) ) .subscribe(value => console.log("filter>"+value)); stream.pipe( filter(val=>val%2==0), map(value => { return value * value }) ) .subscribe(value => console.log("map>"+value));
import {Observable,fromEvent} from 'rxjs'; import {map,filter,throttleTime} from 'rxjs/operators'; var button = document.querySelector('button'); fromEvent(button, 'click').pipe( throttleTime(1000) ) .subscribe(() => console.log(`Clicked`));