网上关于RXJS的教程甚多,我本身在第一次遇到observable变量的时候,也是比较疑惑,以前用惯了promise,对于observable以及其余RXJS相关的用法有些懵逼。我认为,在学习rxjs的相关api和具体用法以前,应该先理解它的工做原理。 总得来讲,observable变量和promise有着不少类似的地方,他们都是处理异步事件的工具,但也有着很大的区别,弄清楚这些区别很是重要。在开始以前,我建议咱们应该先去了解下面这些基础知识(不要求熟练掌握,但要有一个概念)npm
事实上,相似于() => { }这样的用法,就是典型的函数式编程。它将函数做为一个参数使用,也能够赋值给一个变量,做为其余函数的返回值等等。在咱们后面的例子中,你必定会见到不少这样的使用情形。编程
这二者在咱们今天讨论的话题里是一个合做的关系,在咱们一会使用rxjs处理各类异步事件的时候,就会深入地理解这两种设计的模式的含义。 简单来讲,观察者模式就是——A发布消息,B,C,D接收消息。可是注意,这里的BCD是对A进行了一个订阅,就像你如今充了腾讯视频的会员,那么通常默认你会续订,除非你告诉它“我从下个月开始就不订了”或者“我要是没钱了你就别帮我续订了”,不然的话,你会一直对A处于订阅的状态。为何我要跟大家强调这一点,一会的一个应用场景你就明白了。 迭代器模式就好理解多了,顾名思义,就是对一个数据对象内的元素进行按顺序的遍历操做,咱们遇到的数组的foreach()方法,就是一个典型的迭代器模式。c#
推与拉?没错,就是推与拉。这两个反义的动词生动形象地描述了数据生产者和数据消费者的关系。 咱们首先来讲拉。数据消费者决定本身何时须要数据,而后从生产者那里“拉”过来。好比咱们熟知的js函数,就是在咱们的代码中须要调用的时候,才会去消费预先定义好的函数。 好了,在创建了以上概念之后,咱们就能够进入一些关于rxjs的实际练习了。 observable的使用主要就是借助一系列的operator进行,咱们在下面看一下。api
咱们能够经过create方法来建立observable变量,并制定一系列被观察者被订阅后的事件。 这里,咱们对create方法对应的函数传入参数observer,你能够这样理解:用于observable采用的是push的方法,也就是说,observable才是主动的一方!所以这里咱们create出来的observable能够对观察者observer进行一系列的响应事件,这些事件,是由create函数里面的定义实现的。数组
source_create = Observable.create(function (observer) { observer.next('Carl'); observer.next('David'); setTimeout(() => { console.log('after 1 second'); observer.next('Evan'); }, 1000); });
当咱们对上面的observable进行订阅后:promise
this.source_create.subscribe(function (value) { console.log(value); });
会获得这样的输出:Carl, David (一秒后) Evan。异步
咱们能够经过observable.of来对数据进行同步的发射。结合前面经过create方法,看看observable的异步特性。函数式编程
source_of = Observable.of('Andy', 'Billy');
这里咱们声明source_of,让它同步发射Andy, Billy。而且咱们在上面的source_create以后进行订阅。以下代码:函数
this.source_create.subscribe((value) => { console.log(value); }); this.source_of.subscribe((value) => { console.log(value); });
咱们能够获得这样的结果: 工具
能够看到,经过create方法定义中的observer.next方法,发送的值是异步的,Evan会在 Andy和Billy以后进行输出,缘由是咱们设置1秒的timeout,这个时间内,代码会运行到source_of的订阅。
observable.from方法能够对字符串和数组进行异步的发送。
source_from = Observable.from('The pulp fiction');
而且咱们对observer进行这样的定义:
this.source_from.subscribe({ next: (value) => console.log(value), complete: () => console.log('Complete'), });
咱们对结果进行输出可得:
这里能够看到the pulp fiction依次输出,在最后咱们看到了subscribe中定义的complete方法输出的‘Complete’。这是由于咱们在subscribe中定义了complete方法的内容,所以,当source_from的next方法检测到没有结果以后,则会调用observer的complete方法!(你不妨试试,若是不定义complete方法,结果会是怎样的)
上面说到的create, of, from都是observable的建立方法,能够建立不一样形式的数据发布流。我之因此叫它作数据发布流,就是由于咱们使用不一样方法,数据流产生的时间,同异步,间隔,触发方式等等都有区别,就像不一样的发布方式同样,能够是月刊,季刊,批发,本身一本本买等等!这样说,你明白了吗?这就是observable的建立。 要使用上述方法,记得引入rxjs/add/observable/xxx,来获取这些api(除了以上说的三种,还有不少,根据须要查看doc便可)