我想使用RxAlamofire取消之前的请求。 但我不知道在哪里调用取消功能。 我有一个searchBar,我在函数“textdidchange”中调用API。 所以,我想取消之前的请求并使用新参数调用API。 有什么建议可以帮到我吗? 谢谢。
func request(_ method: Alamofire.HTTPMethod, url:String, params:[String:Any] = [:], callback: @escaping (JSON) -> Void) {
var headers:[String:String] = [String:String]()
if token.isEmpty == false {
headers["Authorization"] = "Bearer \(token)"
}
let configuration = URLSessionConfiguration.default
configuration.httpAdditionalHeaders = SessionManager.defaultHTTPHeaders
configuration.timeoutIntervalForRequest = 10.0
_ = SessionManager(configuration: configuration)
.rx.responseJSON(method,
url,
parameters: params,
encoding: ((method == .get) ? URLEncoding.default : JSONEncoding.default),
headers: headers)
.subscribeOn(SerialDispatchQueueScheduler.init(qos: .background))
.subscribe(onNext: { (r, data) in
let json = JSON(data)
if json["status"].stringValue == "success" {
callback(json["responseData"])
}else {
callback(json)
}
}, onError: { (error) in
callback(JSON(error))
})
.addDisposableTo(ResfulAPIDisposeBag)
}
订阅Observable时,生成的对象是包含订阅的Disposable。这种一次性可以手动处理(yourSubscription.dispose()
),或者你可以将它添加到DisposeBag。当处理袋被解除分配时,它所包含的所有一次性用品都被丢弃。在你的代码中,这将是ResfulAPIDisposeBag
。
let subscription = Observable<Int>.interval(0.1, scheduler: MainScheduler.instance)
.debug("manually disposed")
.subscribe()
subscription.dispose()
或者,使用Dispose Bag:
var disposeBag = DisposeBag()
Observable<Int>.interval(0.1, scheduler: MainScheduler.instance)
.debug("using a dispose bag")
.subscribe()
.disposed(by: disposeBag)
// deallocates the first disposeBag and disposes any Disposables inside
disposeBag = DisposeBag()
注意:在最新版本的RxSwift中不推荐使用.addDisposableTo(_)
,而是使用.disposed(by: _)
。
我们需要添加一些延迟,这将在输入后的X秒后启动请求,但前提是短语没有改变。
let searchResults = searchBar.rx.text.orEmpty
.debounce(0.5, scheduler: MainScheduler.instance)
.distinctUntilChanged()
//if search: doesn't finish, the observable is cancelled
.flatMapLatest { query -> Observable<[Repository]> in
if query.isEmpty {
return .just([])
}
return search(query)
.catchErrorJustReturn([])
}
.observeOn(MainScheduler.instance)