Rxjs入门

本文转自我的博客阅读原文

概况

Rxjs是响应式编程思想在JS中的一种实现。那么Rxjs到底是个什么东西呢?装逼地讲,Rxjs是一种融合了函数式编程、观察者模式的以操作为核心的一种编程思想。
Rxjs的适用场景为异步数据流。针对异步的处理是采用观察者模式。针对数据流,我们使用函数式编程中的状态集中管理的理念。
简单说说对面向对象编程与函数式编程的理解吧:
面向对象就是对数据的封装,将具有相关性的数据和方法封装到一个个对象中,以便管理;
函数式编程实际上就是对数据操作的封装,我们只关心数据的输入与输出,至于输入的数据经过了一些什么样的操作最终变成输出的数据,我们是不必在乎的。

核心概念一览

Observable

Observable是事件流的源,相当于观察者模式中的被观察者。可以发射一个个的事件、数据等流。

Operator

Operator是Observable的操作符。体现了函数式编程和迭代器模式的思想。通过各种转变,将Observable流转变为新的Observable流。

Observer

对Observable对象发出的每个事件进行响应。

subscribe()

subscribe()方法用来订阅Observable流。该方法会接受一个observe作为参数,每当observable完成并发送一个事件时,该事件就会被observer所捕获,进入到observer对应的回调函数中。

Subscription

Observable对象被订阅后返回的Subscription实例(可取消订阅)。

Subject

EventEmitter的等价数据结构,可以当做Observable被监听,也可以作为Observer发送新的事件。

一个完整的Rx流

创建Observable对象

将一系列的异步事件封装到Observable流里边。
常用的Observable对象创建方式除了new Observable()还有实用的Observable.fromEvent()和Observable.create()。
Observable.fromEvent():

  let button = document.querySelector('button')
  Rx.Observable.fromEvent(button, 'click') // 返回一个Observable对象
  .subscribe(() => console.log('Clicked!'))

Observable.create():

  Rx.Observable.create(observer => {
    getData(data => {
      observer.next(data)
      observer.complete()
    })
  })
  .subscribe(data => { doSomething(data) })

对Observable流进行各种花式操作

map变换操作符

只返回我们所关心的数据

  observable.map(res => {
    return res.data
  }).subscribe(data => {
    doSomething(data)
  })

filter过滤操作符

过滤掉一些无用数据

  /* 值为true时,才输出该值 */
  observable.filter(res => {
    return !!res.data && res.status == 200
  })

forkJoin组合操作符

某些场景是需要等到两个操作都完成之后才进行的

  Rx.Observable.forkJoin(getFirstDatas, getSecondDatas)
  .subscribe(datas => {
    // datas[0]是getFirstDatas的数据
    // datas[1]是getSecondDatas的数据
  })

concatMap组合操作符

某次数据请求依赖前一次请求的结果

  let getFirstDatas = Rx.Observable.create(observer => {
    // next可以执行一个异步操作,也可以在异步操作后next出异步操作的结果
    observer.next(getFirstData())
    observer.complete()
  })
  let createSecondDatas = function(firstData) {
    return Rx.Observable.create(observer => {
      getSecondData(firstData, secondData) => {
        observer.next(secondData)
        observer.complete()
      }
    })
  }
  getFirstDatas.concatMap(fristData => {
    return createSecondDatas(firstData)
  }).subscribe(secondData => {
    doSomething(secondData)
  })

工具操作符

  • timeout(): 超过指定的时间没有拿到数据就抛出异常
  • debounceTime(): 防止抖动
  • switchMap(): 保证前端拿到的数据是有序的
  // ...
  .switchMap(event => getRecommend(event.target.value))

参考文档

RxJS中文文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容