Observable介绍
Observable
作为RxSwift
的基础,一切的根基基于此,因此,想要透彻理解RxSwift
,我们也要对Observable
要有一些基本的了解。
Observable<T>
Observable<T>
这个类是RxSwift
框架的基础,通常我们把它称作为可观察序列
,它存在的作用就是可以异步的产生一系列的Event
事件。- 产生的这些
Event
事件还可以携带数据,那么泛型<T>
就是用来传递这个Event
事件携带的数据的类型。- 那么既然有了
Observable可观察序列
,我们还需要一个Observer(订阅者)
来订阅它,这样这个订阅者才能收到发出的Event
事件
Event事件
我们进入RxSwift
的源码查看,可以发现事件Event
d的定义如下:
/// Represents a sequence event.
///
/// Sequence grammar:
/// **next\* (error | completed)**
public enum Event<Element> {
/// Next element is produced.
case next(Element)
/// Sequence terminated with an error.
case error(Swift.Error)
/// Sequence completed successfully.
case completed
}
我们可以看到,Event
其实就是一个枚举,因此,可以知道Observable
可以发出3种不同类型的Event
事件:
next:
屏幕快照 2019-07-28 09.34.27.pngnext
事件就是通常携带数据<T>
的事件。
error:
屏幕快照 2019-07-28 09.40.56.pngerror
事件表示一个错误,它携带了具体错误内容,只要Observable
发出了error event
,Observable
就会终止,不会再发出error
事件了。
completed:
屏幕快照 2019-07-28 09.46.01.pngcompleted
事件表示Observable
发出的事件完成了,和error
一样,只要Observable
发出后就终止,不在发出event
事件。
Observable 与 Sequence比较
- 为更好地理解,我们可以把每一个
Observable
的实例想象成于一个Swift
中的Sequence
:
- 即一个
Observable(ObservableType)
相当于一个序列Sequence(SequenceType)
。ObservableType.subscribe(_:)
方法其实就相当于SequenceType.generate()
- 区别:
Swift
中的SequenceType
是同步的循环,而Observable
是异步的。Observable
对象会在有任何Event
时候,自动将Event
作为一个参数通过ObservableType.subscribe(_:)
发出,并不需要使用next
方法。
创建 Observable 序列
RxSwift
为我们提供了以下几种方法来创建一个Observable
序列。
just()方法
- 该方法通过传入一个默认值来初始化,构建一个只有一个元素的
Observable
队列,订阅完信息自动complete
。 - 下面的样例,我们显示地标注出了
Observable
的类型为Observable<Int>
,即指定了这个Observable
所发出的事件携带的数据类型必须是Int
类型的。
let observable = Observable<Int>.just(5)
of()方法
- 该方法可以接受可变数量的参数(必需要是同类型的),创建一个固定数量元素的
Observable
序列。 - 下面样例中我们没有显式地声明出
Observable
的泛型类型,Swift
也会自动推断类型。
let observable = Observable.of("A", "B", "C")
from()方法
- 该方法需要一个
数组/字典/集合
参数,这样的一个序列中创建一个Observable
序列。 - 下面样例中数据里的元素就会被当做这个
Observable
所发出event
携带的数据内容,最终效果同上面of()
样例是一样的。
let observable = Observable.from(["A", "B", "C"])
empty()方法
- 该方法创建一个空内容的
Observable
序列,但是只能订阅到complete
。
let observable = Observable<Int>.empty()
never()方法
- 该方法创建一个永远不会发出
Event
(也不会终止)的Observable
序列。
let observable = Observable<Int>.never()
error()方法
- 该方法创建一个不做任何操作,而是直接发送一个错误的
Observable
序列。
enum MyError: Error {
case A
case B
}
let observable = Observable<Int>.error(MyError.A)
range()方法
- 该方法通过指定起始和结束数值,创建一个以这个范围内所有值作为初始值的
Observable
序列。 - 下面两种方法创建的
Observable
序列都是一样的。
//使用range()
let observable = Observable.range(start: 1, count: 5)
//使用of()
let observable = Observable.of(1, 2, 3 ,4 ,5)
repeatElement()方法
- 该方法创建一个可以无限发出给定元素的
Event
的Observable
序列(永不终止)。
let observable = Observable.repeatElement(1)
generate()方法
- 该方法创建一个只有当提供的所有的判断条件都为
true
的时候,才会给出动作的Observable
序列。 - 两种方法创建的
Observable
序列都是一样的。
//使用generate()方法
let observable = Observable.generate(
initialState: 0,
condition: { $0 <= 10 },
iterate: { $0 + 2 }
)
//使用of()方法
let observable = Observable.of(0 , 2 ,4 ,6 ,8 ,10)
create()方法
- 该方法接受一个
block
形式的参数,任务是对每一个过来的订阅进行处理。 - 下面的样例增加了订阅相关代码(订阅的内容,以后讲)。
//这个block有一个回调参数observer就是订阅这个Observable对象的订阅者
//当一个订阅者订阅这个Observable对象的时候,就会将订阅者作为参数传入这个block来执行一些内容
let observable = Observable<String>.create{observer in
//对订阅者发出了.next事件,且携带了一个数据"hangge.com"
observer.onNext("hangge.com")
//对订阅者发出了.completed事件
observer.onCompleted()
//因为一个订阅行为会有一个Disposable类型的返回值,所以在结尾一定要returen一个Disposable
return Disposables.create()
}
//订阅测试
observable.subscribe {
print($0)
}
deferred()方法
- 该个方法相当于是创建一个
Observable
工厂,通过传入一个block
来执行延迟Observable
序列创建的行为,而这个block
里就是真正的实例化序列对象的地方。 - 演示样例:
//用于标记是奇数、还是偶数
var isOdd = true
//使用deferred()方法延迟Observable序列的初始化,通过传入的block来实现Observable序列的初始化并且返回。
let factory : Observable<Int> = Observable.deferred {
//让每次执行这个block时候都会让奇、偶数进行交替
isOdd = !isOdd
//根据isOdd参数,决定创建并返回的是奇数Observable、还是偶数Observable
if isOdd {
return Observable.of(1, 3, 5 ,7)
}else {
return Observable.of(2, 4, 6, 8)
}
}
//第1次订阅测试
factory.subscribe { event in
print("\(isOdd)", event)
}
//第2次订阅测试
factory.subscribe { event in
print("\(isOdd)", event)
}
interval()方法
- 这个方法创建的
Observable
序列每隔一段设定的时间,会发出一个索引数的元素。而且它会一直发送下去。那么,它的底层其实就是封装timer
。 - 下面方法让其每 1 秒发送一次,并且是在主线程
MainScheduler
发送。
let observable = Observable<Int>.interval(1, scheduler: MainScheduler.instance)
observable.subscribe { event in
print(event)
}
timer()方法
- 这个方法有两种用法,一种是创建的
Observable
序列在经过设定的一段时间后,产生唯一的一个元素。
//5秒种后发出唯一的一个元素0
let observable = Observable<Int>.timer(5, scheduler: MainScheduler.instance)
observable.subscribe { event in
print(event)
}
- 另一种是创建的
Observable
序列在经过设定的一段时间后,每隔一段时间产生一个元素。
//延时5秒种后,每隔1秒钟发出一个元素
let observable = Observable<Int>.timer(5, period: 1, scheduler: MainScheduler.instance)
observable.subscribe { event in
print(event)
}
最后,感谢一下我们的航歌。
网友评论