1

如果它由函数返回,我有并且 observable 永远不会发送 onNext,但是如果我在返回它的函数中订阅它,则会调用 onNext。

class InfoViewModel {

    func refreshPushToken() {

        PushNotificationService.sharedInstance.pushToken!
                .flatMapLatest { (pushToken: String) -> Observable<Result<User>> in
                    return UserService.registerPushToken(pushToken)
                }
                .subscribe { (event ) in
                    print(event)
                }
                .addDisposableTo(disposeBag)

    }
}

struct UserService {
    ....
    static func registerPushToken(_ pushToken: String) -> Observable<Result<User>> {
        ...
        return self.postUser(user: user)
    }

    static fileprivate func postUser(user: User) -> Observable<Result<User>> {

        let rxProvider: RxMoyaProvider<Backend> = RxMoyaProvider<Backend>(endpointClosure: Backend.endpointClosure)

         return rxProvider.request(Backend.register(user: user))
            .mapObject(type: User.self)
            .map({ (user: User) -> Result<User> in
                LogService.log(level: .debug, action: "postUser", message: "Posted user with success", parameters: ["user": user.deviceId])
                return .success(user)
            })
            .catchError({ error -> Observable<Result<User>> in
                LogService.log(level: .error, action: "postUser", message: "Error posting user", parameters: ["user": user.deviceId, "error": error.localizedDescription])
                return Observable.just(.failure(error))
            })
    }   
}

但如果我这样做

     rxProvider.request(Backend.register(user: user))
     ...
        .subscribe { (event ) in
            print(event)
        }

在 UserService 中,我将获得下一个事件。

我曾尝试debug()在 InfoViewModel 中使用 observable,有一个订阅,我只是从未收到任何事件。

4

1 回答 1

0

所以我想通了,我在方法内部创建了 RxMoyaProvider,所以一旦我超出了方法的范围,它就会被释放。这意味着当订阅它时,它不能再创建请求。这不会失败的原因是因为 observable 是如何创建的

open func request(_ token: Target) -> Observable<Response> {

        // Creates an observable that starts a request each time it's subscribed to.
        return Observable.create { [weak self] observer in
            let cancellableToken = self?.request(token) { result in
                switch result {
                case let .success(response):
                    observer.onNext(response)
                    observer.onCompleted()
                case let .failure(error):
                    observer.onError(error)
                }
            }

            return Disposables.create {
                cancellableToken?.cancel()
            }
        }
    }

如您所见,该请求是在订阅时调用的,但由于self已被释放,因此该请求从未被触发。我得到的只是一个空的 observable。

于 2017-01-04T22:14:06.750 回答