RXSwift笔记

  • 观察者模式:KVO、通知
  • 被观察者:发出一个事件
  • 观察者/订阅者:对被观察者对象进行响应

RXSwift:把程序中每一个操作看成一个事件。例如:点击事件,filed文本改变、请求完成等,每一个事件源可以看成一个管道,也就是sequence(序列)。
例如:testFiled文本改变时,就会不断的发出事件,就会从他的这个sequence管道中不断流出,只需监听这个sequence(可监听序列),每流出一个事件就做相应的处理。
总结:将事件包装在一个序列里面,我们只需要监听从序列里面不断流出的事件即可。

序列:

Observable:对观察者发送全部的元素,无论观察者是何时进行订阅的。ReplaySubject会受bufferSize影响。

创建一个序列的一般方法伪代码:
 let json: Observable<泛型约束,事件类型:如JSON、[String:AnyHasble]、Data、Int> = Observable.create { observer -> Disposable in
    if (a) {
        observer.onNext(0)
    }else if (b) {
        observer.onNext(1)
        observer.onCompleted()
    }else {
        observer.onError(error!)
    }
    return Disposables.create()
 }

特征序列:

特征序列一:

不会共享附加作用:
主要用于数据请求、业务逻辑上:

  • Single: 发出一个元素,或一个 error 事件
  • Completable: 发出零个元素;发出一个 completed 事件或者一个 error 事件
  • Maybe: 发出一个元素或者一个 completed 事件或者一个 error 事件
特征序列二:

共享附加作用
不会产生 error 事件
一定在MainScheduler监听(主线程监听)
主要用于UI事件的生成序列上:

  • Driver:会对新观察者回放(重新发送)上一个元素。 .asDriver(); event.drive(onNext: newObserver)
    状态序列一般选用 Driver 这个类型
  • Signal:不会对新观察者回放上一个元素。 .asSignal(); event.emit(onNext: newObserver)
    事件序列一般选用 Signal 这个类型。

Observer 观察者/订阅者:用来监听事件,然后对这个事件做出响应。

 subscribe(onNext: { [weak self] in
     self?.showAlert()
 }, onError: { error in
     print("发生错误: \(error.localizedDescription)")
 }, onCompleted: {
     print("任务完成")
 })

特征观察者:

  • AnyObserver:可以用来描叙任意一种观察者。(也就是可以把序列上的直接观察者.subscribe(onNext:)或者.bind(to:)提取封装出来,转化成.subscribe(observer)或者.bind(to: observer))
  • Binder:UI观察者;1、不会处理错误事件;2、确保绑定都是在给定 Scheduler 上执行(默认 MainScheduler)
let observer: Binder = Binder(usernameValidOutlet) { (view, isHidden) in
    view.isHidden = isHidden
}
 .bind(to: observer) <==等价于==> .bind(to: usernameValidOutlet.rx.isHidden)

既是可监听序列Observable也是观察者Observer, 既可发出事件也可监听事件。

例如:textField的当前文本。
// 作为可监听序列 ----它可以看成是由用户输入,而产生的一个文本序列

 let observable = textField.rx.text
 observable.subscribe(onNext: { text in show(text: text) })

// 作为观察者 ----由外部文本序列,来控制当前textField显示内容的观察者

 let observer = textField.rx.text
 text.bind(to: observer)

辅助类型:它们既是可监听序列也是观察者。可以帮组更准确的描述事物的特征:

  • AsyncSubject:对观察者发送的全部的元素中,无论观察者是何时进行订阅的,发出最后一个元素(仅仅只有最后一个元素)。或第一个onCompleted/onError元素(序列结束)。
  • PublishSubject:对观察者发送订阅后产生的元素,而在订阅前发出的元素将不会发送给观察者。
  • ReplaySubject:对观察者发送”全部“(受bufferSize影响)的元素,无论观察者是何时进行订阅的。有的只会将最新的 n 个元素发送给观察者,有的只会将限制时间段内最新的元素发送给观察者(具体元素个数根据bufferSize设置)。
  • BehaviorSubject:首先会将最新的元素发送出来,如果不存在最新的元素,就发出默认元素。然后将随后产生的元素发送出来。 (先发订阅前的最新的一个元素,没有则发送默认【BehaviorSubject(value: "默认元素")】,然后再发送之后的元素)

操作符:

对序列中的事件做相应的操作(如:遍历、filter过滤、map转换、zip配对),生成新的序列。

Disposable - 可被清除的资源

一个序列如果发出了 error 或者 completed 事件,那么所有内部资源都会被释放。

  • 清除包(DisposeBag) 或者 takeUntil 操作符 来管理订阅的生命周期。
  • 清除包被释放的时候,清除包内部所有可被清除的资源(Disposable)都将被清除。
self.disposable = textField.rx.text.orEmpty.subscribe(onNext: { text in print(text) })
self.disposable?.dispose()

调用 dispose 方法后,订阅将被取消,并且内部资源都会被释放。

_ = usernameValid.takeUntil(self.rx.deallocated).bind(to: passwordOutlet.rx.isEnabled)//订阅一直持续到控制器的dealloc事件产生为止。
使用takeUntil操作符:实现自动取消订阅的方法

Schedulers - 调度器

  • subscribeOn:数据序列的构建函数在哪个 Scheduler 上运行。
  • observeOn:在哪个 Scheduler 监听这个数据序列。
  1. MainScheduler 代表主线程。
  2. SerialDispatchQueueScheduler 抽象了串行 DispatchQueue。
  3. ConcurrentDispatchQueueScheduler 抽象了并行 DispatchQueue。
  4. OperationQueueScheduler 抽象了 NSOperationQueue。

你可能感兴趣的:(RXSwift笔记)