RxSwift -- 基础

RxSwift 是什么

RxSwift 是Rx框架的 Swift 实现.
关于 Rx 框架引用一段介绍https://mcxiaoke.gitbooks.io/rxdocs/content/Intro.html

ReactiveX是Reactive Extensions的缩写,一般简写为Rx,最初是LINQ的一个扩展,由微软的架构师Erik Meijer领导的团队开发,在2012年11月开源,Rx是一个编程模型,目标是提供一致的编程接口,帮助开发者更方便的处理异步数据流,Rx库支持.NET、JavaScript和C++,Rx近几年越来越流行了,现在已经支持几乎全部的流行编程语言了,Rx的大部分语言库由ReactiveX这个组织负责维护,比较流行的有RxJava/RxJS/Rx.NET,社区网站是 reactivex.io

框架的主要目的是为了处理异步数据流. 例如, 异步网络请求, 事件响应等

RxSwift 的意义及为何要使用这个框架

简单来说, 你可以更方便高效的写代码. 例如官方这个炫酷的 demo, 你也可以很方便的写出来


Github 搜索

而且合理使用各种合并, map, flatmap 等, 你几乎可以完成所有的事情.

入门

首先我们要导入 RxSwift. 只需要在 Pod 文件中加入这一行

pod 'RxSwift',    '~> 3.0'

成功导入之后,
我们来看一个最基本的 Hello, word

class SomeViewController: UIViewController {
...
 let disposeBag = DisposeBag()
....
  override func viewDidLoad() {
    Observable.just("Hello, world").subscribe(onNext: { (str) in
                print(str)
            }).disposed(by: disposeBag)
   }
...

这个示例会输出Hello, world
不过你现在觉得一头雾水, 这是什么? Observable 是什么东西?

基础概念

RxSwift 中大量使用到观察者模式. 这个模式在 iOS 中应用最广泛的就是通知了.

Observable

Observable 是一个可观察的对象, 类似于 NotificationCenter
我们使用 just 这个工厂方法, 创建了一个可观察者对象, 并在其中放了一个事件, 这个事件内容就是这个"Hello, world" 字符串, 并随即事件链结束. 相当于使用 NotificationCenter.default.post(xxx), 不过这里略有不同的是, 通知会立即发送, 而可观察对象通常会在有订阅者订阅的时候才会创建事件并发送.

subscribe

subscribe(onNext:) 则是订阅, 相当于 NotificationCenter.default.addObserver. Observable 中有三种事件, 分别是完成completed, 错误 error(Error), 下一个"next(Element)". 这里的 next 事件看似难以理解, 其实只是说发生了某一个事件而已. 关于事件, 后面我们再细说.
回到之前的代码, subscribe(onNext:) 则表示我们要订阅一个 next 事件. 之前提到, just 函数会在发送一次事件之后立即结束, 这里我们也可以通过订阅来看到, 修改代码为如下代码, 以打印所有事件

Observable.just("Hello, world").subscribe { (event) in
    print(event)
}.disposed(by: disposeBag)

可以看到, 事件的顺序是next(Hello, world) => completed

disposeable

这个用于清理空间, 以及完成某些收尾工作.
subscribe 后, 会返回一个disposeable 对象, 可以将这个对象放入某个 disposeBag , 当这个disposeBag 对象被释放的时候, 会同时销毁所有与之关联的disposeable对象.

事件

RxSwift 中最重要的就是事件, 核心就是若干消息的消息链处理.
除了我们之前用到的just 之外, 还有一些其他方法可以产生多次事件, 例如of

Observable.of("Hello", "world").subscribe { (event) in
    print(event)
}.disposed(by: disposeBag)

这段代码的输出结果为

next(Hello)
next(world)
completed

RxSwift 中只有两种事件链, 一种是无尽的的, 也就是没有complete 事件. 一种则是有限长度的.
-1-2-3-4-| 这个是有限长度的事件链, 1, 2, 3, 4 是事件, | 是结束标记
-1-2-3-4- 这个则是无限的长度的事件链, 因为并没有结束符
-1-2-3-4-× 则表示发生了错误, × 表示错误
需要注意的是, 只要了错误或者发送了结束事件, 那么后续所有的事件都会被忽略

创建自定义事件链

如果系统定义的事件链不能满足需要, 你需要自定义, 你可以 create 来办到这一点
例如, 我们来写一个跟 just 类似的, 只发送一个事件后就立即结束事件链

Observable<String>.create { (observer) -> Disposable in
    observer.onNext("Hello, world")
    observer.onCompleted()
    return Disposables.create {}
}.subscribe { (event) in
    print(event)
}.disposed(by: disposeBag)

这里, 你可以更细致的看到整个事件的全过程. 其中<String> 表示事件的元素类型.
一共步骤就只有4步, 创建, 发送事件, 发送结束标记, 处理 dispose
你可能会对 create 里面的observer 感到困惑, 为何这里的是观察者, 明明创建的是一个可观察对象? 你只需要明白, 可观察者在获取到事件后, 他并不是自己处理, 而是将这个事件传递给观察者.
当你了解到这点之后, 你也许灵光一闪, 想到可以用来处理网络事件

Observable<String?>.create { (observer) -> Disposable in
    let task = URLSession.shared.dataTask(with: URL(string: "https://httpbin.org/get")!, completionHandler: { (data, _, error) in
        if error != nil {
            observer.onError(error!)
        } else {
            if data == nil {
                observer.onNext(nil)
            } else {
                observer.onNext(String(data: data!, encoding: .utf8))
            }
            observer.onCompleted()
        }
    })
    task.resume()
    return Disposables.create {
        task.cancel()
    }
}.subscribe { (event) in
    print(event)
}.disposed(by: disposeBag)

看到了吗, 就这么简单. 你甚至可以通过使用 map 来改变事件内容
例如

...与上面代码一样
.map{ $0 ?? "empty result" }
 .subscribe { (event) in
     print(event)
 }.disposed(by: disposeBag)

你看到这里, 就表示你已经基本上入门了, 接下来, 你将会学习很多的操作符.

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

推荐阅读更多精彩内容