Создание Observable в RxSwift
В этой заметке мы рассмотрим некоторые методы, используемые при создании Observable в RxSwift. Observable — наблюдаемый объект или то, что будет отдавать данные. Если говорить о парадигме реактивного программирования на iOS с помощью фреймворка RxSwift, то Observable нужен для генерации потока данных.
asObservable
Данный метод реализован в классах RxSwift, когда они поддерживают конвертацию в Observable. К примеру: ControlProperty, Variable, ControlEvent, Driver.
example("\"asObservable\"") { let variable = Variable(0) variable .asObservable() .subscribe({ event in print(event) }) variable.value = 1 }
Вывод в консоли будет следующим:
--- "asObservable" example --- next(0) next(1) completed
В нашем примере мы преобразовали Variable в Observable, а также подписались на его события.
create
Следующий метод даёт возможность разработчику создавать Observable с нуля. При этом разработчик полностью контролирует, какие именно элементы он будет генерировать и когда.
example("\"create\"") { Observable .create({ observer in observer.on(.next(1)) observer.on(.next(2)) observer.on(.next("A")) observer.on(.next("B")) observer.onCompleted() return Disposables.create() }) .subscribe({ event in print(event) }) }
Смотрим консоль:
--- "create" example --- next(1) next(2) next(A) next(B) completed
Таким образом, мы только что создали Observable. Он, в свою очередь, сгенерирует несколько значений. В конце будет вызван complete.
deferred
Данный оператор даёт возможность отложить создание Observable вплоть до момента подписки посредством subscribe.
example("without \"deferred\"") { var i = 1 let observable = Observable.just(i) i = 2 observable .subscribe({ event in print(event) }) } example("with \"deferred\"") { var i = 1 let observable = Observable.deferred({ Observable.just(i) }) i = 2 observable .subscribe({ event in print(event) }) }
Консоль:
--- without "deferred" example --- next(1) completed --- with "deferred" example --- next(2) completed
В первом случае Observable будет создан сразу посредством