RxSwift、RxBlocking、RxTest初尝试

简介: 在Android开发上,RxJava已经是非常重要的组成之一。最近在用Swift开发iOS应用,考虑在架构设计上使用RxSwift。添加依赖# Podfileuse_frameworks!target 'YOUR_TARGET_NAME' do pod 'RxSwift', '~...

在Android开发上,RxJava已经是非常重要的组成之一。最近在用Swift开发iOS应用,考虑在架构设计上使用RxSwift。

添加依赖
# Podfile
use_frameworks!

target 'YOUR_TARGET_NAME' do
    pod 'RxSwift', '~> 5'
    pod 'RxCocoa', '~> 5'
    pod 'RxBlocking', '~> 5'
end

# RxTest and RxBlocking make the most sense in the context of unit/integration tests
target 'YOUR_TESTING_TARGET' do
    
    pod 'RxTest', '~> 5'
end
创建 Observable
import RxSwift
...

let observable = Observable<Int>.create { (observer) -> Disposable in
    observer.onNext(1)
    observer.onCompleted()
    return Disposables.create()
}
定义 onError调用
struct MyError:Error {
    var message = ""
    init(message:String) {
        self.message = message
    }
}
let observable = Observable<Int>.create { (observer) -> Disposable in
    let error = MyError(message: "Test Error")
    observer.onError(error)
    return Disposables.create()
}
subscribe

只定义一个回调

observable.subscribe({ it in
    print("onNext \(it.element)")
})

定义onNext和onError

observable.subscribe(onNext: { it in
    print("onNext \(it)")
},onError: { error in
    print((error as! MyError).message)
})

定义onNext、onError和onCompleted

observable.subscribe(onNext: { it in
    print("onNext \(it)")
},onError: { error in
    print((error as! MyError).message)
},onCompleted: {

})

RxBlocking

RxBlocking是RxSwift中另外一个单独的框架。跟RxTest一样,也需要进行pod引入框架,需要单独添加依赖。RxBlocking可以把RxSwift从异步响应变成同步,所以RxBlocking也多用来做单元测试。

    pod 'RxBlocking'
import RxSwift
import RxBlocking
...

do{
    let result = try observable.toBlocking().first()
    print("结果:\(result)")
}catch{
    print((error as! MyError).message)
}
应用场景

比如我们使用RxSwift实现图片上传,在发布动态的时候需要先上传图片然后调用基于RxSwift实现的网络请求。加上我们不想嵌套调用,就可以通过toBlocking同步调用。

RxTest

RxTest 是可以用来构建RxSwift自动化测试的包,需要单独需要进行pod引入框架。

相关文章
RxSwift观察者AnyObserver、Binder的使用
RxSwift观察者AnyObserver、Binder的使用
138 0
|
8月前
|
JavaScript 前端开发 中间件
【掰开揉碎】Redux 和 Context 到底怎么选
【掰开揉碎】Redux 和 Context 到底怎么选
175 0
DragonBones骨骼动画事件系统详解
DragonBones骨骼动画事件系统详解
143 0
|
API Swift iOS开发
|
前端开发
RxSwift-双向绑定
RxSwift-双向绑定
309 0
|
Android开发 开发者 容器
Android事件分发机制
Android事件分发机制
探秘 RxJS Observable 为什么要长成这个样子?!
我们都知道 RxJS Observable 最基础的使用方法:是建立 Observable,即调用 .create API
|
JavaScript
手写代码:实现一个EventBus
EventBus,事件总线。总线一词来自于《计算机组成原理》中的”系统总线“,是指用于连接多个部件的信息传输线,各部件共享的传输介质。我们通常把事件总线也成为自定义事件,一般包含`on`、`once`、`emit`、`off`等方法。在Vue2中想要实现EventBus比较简单,直接暴露出一个`new Vue()`实例即可,以此为思路,我们应该如何自定义实现EventBus呢?
531 0
手写代码:实现一个EventBus
|
Android开发 容器
事件分发四部曲之一《深度遍历讲解Android事件分发机制》
事件分发四部曲之一《深度遍历讲解Android事件分发机制》
事件分发四部曲之一《深度遍历讲解Android事件分发机制》
|
Android开发
事件分发四部曲之二《嵌套滑动事件分析》
事件分发四部曲之二《嵌套滑动事件分析》
事件分发四部曲之二《嵌套滑动事件分析》