可以这么说,响应式编程是继承自函数式编程。从Rx的官网上我们看到这样的定义:
RxJS是结合了观察者模式,迭代器模式和函数式编程优点的产物。
观察者模式在前文中已经出现过了,下面我们来看看函数式编程和迭代器模式。
函数式编程
函数式编程是一种开发软件的范式,强调使用函数来创建应用程序。声明式的,不可变的,没有副作用的是函数式编程的三大护法。
其中不可变
武功最高深。一直使用面向对象范式编程的我们,习惯了用变量存储和追踪程序的状态。然而我们如何在变量不可变的情况下来完成同样的功能呢?这里举个钟表时间的例子,从早上7点到早上8点,存储时间的变量必然从7变成了8。用函数式的观点,不能改变变量的值,那如何追踪时间的变化,那就每走一秒,我们就重新创建个钟表,在程序中就是新创建个实例,最终,我们得到的结果都是指向8点的钟表。
RxJS从函数式编程范式中借鉴了很多东西,比如链式函数调用,惰性求值等等。
其他两大护法,我们简单说一下。什么叫声明式的语句,请参看SQL查询语句的写法。没有副作用的,我们就看看什么是副作用:在函数中与函数作用域之外的一切事物有交互的就产生了副作用。比如读写文件,在控制台打印语句,修改页面元素的css等等。在RxJS中,把副作用问题推给了订阅者来解决。其实副作用这个问题,大家早已熟悉了——编程中最忌讳的全局变量。说白了,共享的都是不安全的,尤其是在多线程,异步环境下,在这里就不多说了。函数式编程我会单开haskell系列来讲。
迭代器模式
RxJS中一个关键的设计理念是遍历机制。了解过迭代器设计模式的人应该清楚,迭代器模式的主题思想就是不管要遍历的数据结构是什么,树也好,图也好,我们都用同样的方式操作它们(for...of)。在ES6中引入了迭代器协议,具体内容请参见http://es6.ruanyifeng.com/#docs/iterator。RxJS中的消费者(observer)也实现了类似的协议用来通知生产者(observable)继续发送数据。
数据驱动开发
RxJS鼓励使用数据驱动的方式进行开发。数据驱动可以把数据和处理数据的行为分隔开来,这也是RxJS的核心设计决定,使我们可以用同样的方式处理不同的数据源。