创建Observer

观察者

观察者作用就是监听事件, 然后对这个事件做出响应, 或者说任何响应时间的行为都是观察者

1. 在subscribe()方法中创建监听者

  • 创建观察者最直接的方法就是在Observablesubscribe()方法后面描述事件发生时, 需要如何做出响应
let observable1 = Observable.of("A", "B", "C", "D")
observable1.subscribe(onNext: { element in
    print(element)
}, onError: { error in
    print(error)
}, onCompleted: {
    print("completed")
}).disposed(by: bag)

2. 在bind()方法中创建

let observable = Observable<Int>.interval(1, scheduler: MainScheduler.instance)

observable.map { "索引: \($0)" }.bind { self.label.text = $0 }.disposed(by: bag)

3. 使用AnyObserver来创建观察者

  • AnyObserver可以用来描述任意一种观察者
let observer3: AnyObserver<String> = AnyObserver { (event) in
    switch event {
    case .next(let data):
        print(data)
    case .error(let error):
        print(error)
    case .completed:
        print("completed")
    }
}
let observable3 = Observable.of("A", "B", "C", "D")
observable3.subscribe(observer3).disposed(by: bag)
  • 配合bindTo方法使用
let observer31: AnyObserver<String> = AnyObserver { (event) in
    switch event {
    case .next(let text):
        self.label.text = text
    default:
        break
    }
}
let observable31 = Observable<Int>.interval(1, scheduler: MainScheduler.instance)
observable31.map { "当前索引: \($0)" }.bind(to: observer31).disposed(by: bag)

4. 使用Binder创建观察者

  • 相较于AnyObserver的大而全, Binder更专注于特定的场景. Binder主要有以下两个特征
    • 特征1: 不会处理错误事件
    • 特征2: 确保绑定都是在给定Schedule上执行(默认MainSchedule)
  • 一旦发生错误事件, 在调试环境下将执行fatalError, 在发布环境下将打印错误信息
  • 在上面序列数显示样例中, label标签的文字显示就是一个典型的UI观察者.他在响应事件时, 只会处理next事件, 而且更新UI的操作需要在主线程上执行. 那么这种情况更好的方案就是使用Binder
let observer4: Binder<String> = Binder(label) { (view, text) in
    view.text = text
}
let observable4 = Observable<Int>.interval(1, scheduler: MainScheduler.instance)
observable4.map{ "索引显示: \($0)" }.bind(to: observer4).disposed(by: bag)
posted @ 2019-11-08 15:18  Chaos_G  阅读(290)  评论(0编辑  收藏  举报