Frequently used extensions in RxSwift
This library based on questions from KakaoTalk open chat room.
Join us if you have some questions about RxSwift or you are interested. We always welcome ๐
However, this chat room us operating in South Korea. Therefore, you will need speaking Korean ๐ฐ๐ท
์ด ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ ์นด์นด์คํก ์คํ ์ฑํ
๋ฐฉ์์ ์ฌ๋ผ์จ ์ง๋ฌธ์ ๋ฐํ์ผ๋ก ๋ง๋ค์ด์ก์ต๋๋ค.
RxSwift์ ๊ด๋ จํ์ฌ ์ง๋ฌธ์ด ์๊ฑฐ๋ ๊ด์ฌ์ด ์๋ค๋ฉด ์ธ์ ๋ ์ง ๊ฐ๋ฒผ์ด ๋ง์์ผ๋ก ์ฐธ์ฌํ์ธ์ ๐
์ด ๋ฐฉ์ ํ๊ตญ์์ ์ด์๋๋ ๊ฒ์ด๋ผ ํ๊ตญ์ด๋ฅผ ํ์๋ก ํ ์ ์์ต๋๋ค... (์ด๊ฑฐ ์ฝ์ผ์ค ์ ๋๋ฉด ๋ฌธ์ ์์ ๊ฒ๋๋ค ๐)
ใใฎใฉใคใใฉใชใผใฏใซใซใชใใผใฏใชใผใใณใใฃใใใซใผใ ใซๆ็จฟใใใ่ณชๅใๅบใซไฝใใใพใใใ
RxSwiftใซใคใใฆ่ณชๅใ่ๅณใใใใฐใใใคใงใๆฐ่ปฝใซๅๅ ใใฆใใ ใใ ๐
ใใฎใซใผใ ใฏ้ๅฝใงๅถๆฅญใใใฆใใใใฎใชใฎใง้ๅฝ่ชใๅฟ
่ฆใจใใพใ ๐ฐ๐ท
UIKit
-
UIView
-
UILabel
-
UITextView
-
UITableView
-
UITableViewCell
-
UITableViewHeaderFooterView
-
UICollectionView
-
register(cell: UICollectionReusableView.self, forSupplementaryViewOfKind kind: String)
-
register(nibCell: UICollectionReusableView.self, forSupplementaryViewOfKind kind: String)
-
dequeue(UICollectionViewCell.self, for indexPath: IndexPath)
-
dequeue(UICollectionViewCell.self, ofKind kind: String, for indexPath: IndexPath)
-
UICollectionReusableView
-
UIViewController
-
UIViewController.rx.viewDidLoad
-
UIViewController.rx.viewWillAppear
-
UIViewController.rx.viewDidAppear
-
UIViewController.rx.viewWillDisappear
-
UIViewController.rx.viewDidDisappear
-
UIViewController.rx.viewWillLayoutSubviews
-
UIViewController.rx.viewDidLayoutSubviews
-
UIViewController.rx.willMove(toParentViewController: UIViewController)
-
UIViewController.rx.didMove(toParentViewController: UIViewController)
-
UIViewController.rx.didReceiveMemoryWarning
-
UIViewController.rx.isVisible
-
UIViewController.rx.isDismissing
-
RxSwift
RxCocoa
-
SharedSequenceConvertibleType
Swift
-
KVO
-
observe(keyPath: KeyPath) -> Observable
Observe KVO by keyPath
KVO is an Objective-C mechanism. That means that it wasn't built with type safety in mind. This project tries to solve some of the problems.
UIView() .observe(\.bounds, , options: [.initial, .new], retainSelf: true) .subscribe({ print($0) })
-
observeWeakly(keyPath: KeyPath) -> Observable
Observe KVO by keyPath
rx.observeWeakly
has somewhat slower thanrx.observe
because it has to handle object deallocation in case of weak references.UIView() .observeWeakly(\.bounds, , options: [.initial, .new], retainSelf: true) .subscribe({ print($0) })
-
-
SectionDataType
Define Section Data easily in tableView or collectionView
Define follow
enum TestSectionData { case section1 case section2([Value]) } extension TestSectionData: SectionDataType { typealias Item = Value var items: [TestSectionData.Value] { switch self { case .section1: return [.string("Section 1")] case let .section2(value): return value } } enum Value { case string(String) case int(Int) } }
You can use it follow
let section = sections[indexPath.section].items[indexPath.row] switch section { case let .int(value): cell.set(value) return cell case let .string(value): cell.set(value) return cell }
UIKit
-
UIView
-
UIView.rx.bounds
Observe bounds in UIView
UIView().rx.bounds.subscribe({ print($0) })
-
UIView.rx.center
Observe center in UIView
UIView().rx.center.subscribe({ print($0) })
-
-
UILabel
-
UILabel.rx.textColor
Binder textColor in UILabel
Observable<UIColor?>.just(UIColor.white).bind(to: UILabel().rx.textColor)
-
-
UITextView
-
UITextView.rx.textColor
Binder textColor in UITextView
Observable<UIColor?>.just(UIColor.white).bind(to: UITextView().rx.textColor)
-
-
UIScrollView
-
UIScrollView.rx.contentSize
Observe contentSize in UIScrollView
UIScrollView().rx.contentSize.subscribe({ print($0) })
-
UIScrollView.rx.scrollableVertical
Observe scrollable of vertical (
bounds.height < contentSize.height
) in UIScrollViewUIScrollView().rx.scrollableVertical.subscribe({ print($0) })
-
UIScrollView.rx.scrollableHorizontal
Observe scrollable of horizontal (
bounds.width < contentSize.width
) in UIScrollViewUIScrollView().rx.scrollableHorizontal.subscribe({ print($0) })
-
-
UITableView
-
UITableView.register(cell: UITableViewCell.self)
Register UITableViewCell easily
Following sample will be register with "Cell" (
UITableViewCell.Identifier
).UITableView().register(cell: Cell.self)
Also you can define Identifier like follow
UITableView().register(cell: Cell.self, forCellReuseIdentifier: "CustomIdentifier")
-
UITableView.register(nibCell: UITableViewCell.self)
Register UITableViewCell using NIB easily
Following sample will be register with "Cell" (
UITableViewCell.Identifier
).UITableView().register(nibCell: Cell.self)
Also you can define Identifier like follow
UITableView().register(nibCell: Cell.self, forCellReuseIdentifier: "CustomIdentifier")
-
UITableView.register(cell: UITableViewHeaderFooterView.self)
Register UITableViewHeaderFooterView easily
FolloFollowing sample will be register with "Cell" (
UITableViewHeaderFooterView.Identifier
).UITableView().register(cell: Cell.self)
Also you can define Identifier like follow
UITableView().register(cell: Cell.self, forCellReuseIdentifier: "CustomIdentifier")
-
UITableView.register(cell: UITableViewHeaderFooterView.self)
Register UITableViewCell using NIB easily
FolloFollowing sample will be register with "Cell" (
UITableViewHeaderFooterView.Identifier
).UITableView().register(cell: Cell.self)
Also you can define Identifier like follow
UITableView().register(cell: Cell.self, forCellReuseIdentifier: "CustomIdentifier")
-
UITableView.dequeue(UITableViewCell.self)
Dequeue UICollectionViewCell easily
Following sample will be dequeue with "Cell" (
UICollectionReusableView.Identifier
).let cell: Cell? = UITableView().dequeue(Cell.self)
-
UITableView.dequeue(UITableViewCell.self, indexPath: IndexPath)
Dequeue UICollectionViewCell easily
Following sample will be dequeue with "Cell" (
UICollectionReusableView.Identifier
).let cell: Cell? = UITableView().dequeue(Cell.self, indexPath: IndexPath)
-
UITableView.dequeue(UITableViewHeaderFooterView.self)
Dequeue UITableViewHeaderFooterView easily
let cell: Cell? = UITableView().dequeue(Cell.self)
-
UITableView.rx.items(Cell.self)
Bind items by rx
Observable.just(["0", "1", "2", "3"]) .bind(to: tableView.rx.items(cell: Cell.self)) { row, item, cell in }
-
-
UITableViewCell
-
UITableViewCell.Identifier
Define Identifier by class name
class MyCell: UITableViewCell { } MyCell.Identifier == "MyCell"
-
-
UITableViewHeaderFooterView
-
UITableViewHeaderFooterView.Identifier
Define Identifier by class name
class MyCell: UITableViewHeaderFooterView { } MyCell.Identifier == "MyCell"
-
-
UICollectionView
-
UICollectionView.register(cell: UICollectionViewCell.self)
Register UICollectionViewCell easily
Following sample will be register with "Cell" (
UICollectionReusableView.Identifier
).UICollectionView().register(cell: Cell.self)
Also you can define Identifier like follow
UICollectionView().register(cell: Cell.self, forCellWithReuseIdentifier: "CustomIdentifier")
-
UICollectionView.register(nibCell: UICollectionViewCell.self)
Register UICollectionViewCell using NIB easily
Following sample will be register with "Cell" (
UICollectionReusableView.Identifier
).UICollectionView().register(nibCell: Cell.self)
Also you can define Identifier like follow
UICollectionView().register(nibCell: Cell.self, forCellWithReuseIdentifier: "CustomIdentifier")
-
UICollectionView.register(cell: UICollectionReusableView.self, forSupplementaryViewOfKind: SupplementaryViewOfKind)
Register UICollectionReusableView for SupplementaryViewOfKind
UICollectionView().register(cell: Cell.self, forSupplementaryViewOfKind: .header) UICollectionView().register(nibCell: Cell.self, forSupplementaryViewOfKind: .footer)
-
UICollectionView.dequeue(UICollectionViewCell.self, for: IndexPath)
Dequeue UICollectionViewCell easily
Following sample will be dequeue with "Cell" (
UICollectionReusableView.Identifier
).let cell: Cell? = UICollectionView.dequeue(Cell.self, for: IndexPath)
-
UICollectionView.dequeue(UICollectionReusableView.self, ofKind: SupplementaryViewOfKind, for: IndexPath)
DeDequeue UICollectionReusableView for SupplementaryViewOfKind easily
let cell: Cell? = UICollectionView.dequeue(Cell.self, ofKind: .header, for: IndexPath)
-
UICollectionView.rx.items(Cell.self)
Bind items by rx
Observable.just(["0", "1", "2", "3"]) .bind(to: collectionView.rx.items(cell: Cell.self)) { row, item, cell in }
-
-
UICollectionReusableView
-
UICollectionReusableView.Identifier
Define Identifier by class name
class MyCell: UICollectionReusableView { } MyCell.Identifier == "MyCell"
-
-
UIViewController
-
UIViewController.rx.viewDidLoad
Observe when called `viewDidLoad` in UIViewControllerUIViewController().rx.viewDidLoad.subscribe({ print($0) })
-
UIViewController.rx.viewWillAppear
Observe when called `viewWillAppear` in UIViewControllerUIViewController().rx.viewWillAppear.subscribe({ print($0) })
-
UIViewController.rx.viewDidAppear
Observe when called `viewDidAppear` in UIViewControllerUIViewController().rx.viewDidAppear.subscribe({ print($0) })
-
UIViewController.rx.viewWillDisappear
Observe when called `viewWillDisappear` in UIViewControllerUIViewController().rx.viewWillDisappear.subscribe({ print($0) })
-
UIViewController.rx.viewDidDisappear
Observe when called `viewDidDisappear` in UIViewControllerUIViewController().rx.viewDidDisappear.subscribe({ print($0) })
-
UIViewController.rx.viewWillLayoutSubviews
Observe when called `viewWillLayoutSubviews` in UIViewControllerUIViewController().rx.viewWillLayoutSubviews.subscribe({ print($0) })
-
UIViewController.rx.viewDidLayoutSubviews
Observe when called `viewDidLayoutSubviews` in UIViewControllerUIViewController().rx.viewDidLayoutSubviews.subscribe({ print($0) })
-
UIViewController.rx.willMove(toParentViewController: UIViewController)
Observe when called `willMove(toParentViewController: UIViewController)` in UIViewControllerUIViewController().rx.willMove(toParentViewController: parentViewController).subscribe({ print($0) })
-
UIViewController.rx.didMove(toParentViewController: UIViewController)
Observe when called `didMove(toParentViewController: UIViewController)` in UIViewControllerUIViewController().rx.didMove(toParentViewController: parentViewController).subscribe({ print($0) })
-
UIViewController.rx.didReceiveMemoryWarning
Observe when called `didReceiveMemoryWarning` in UIViewControllerUIViewController().rx.didReceiveMemoryWarning.subscribe({ print($0) })
-
UIViewController.rx.isVisible
Triggered when the ViewController appearance state changes (true if the View is being displayed, false otherwise)UIViewController().rx.isVisible.subscribe({ print($0) })
-
UIViewController.rx.isDismissing
Triggered when the ViewController is being dismissedUIViewController().rx.isDismissing.subscribe({ print($0) })
-
RxSwift
-
ObservableType
-
withLatestFrom
Extend withLatestFrom for support multi parameters
let a = Observable.just("A") let b = Observable.just("B") let c = Observable.just("C") Observable().withLatestFrom(a, b, c) .subscribe(onNext: { (a, b, c) in ... })
-
withLatestFromAndSelf
Extend withLatestFromAndSelf for combining parameters with self
let a = Observable.just("A") let b = Observable.just("B") let c = Observable.just("C") Observable().withLatestFromAndSelf(a, b, c) .subscribe(onNext: { (a, b, c) in ... })
-
bind(to [ObserverType?]?)
Can bind multiple ObserverType in one line
let publisher = PublishSubject<String>() let observers: [PublishSubject<String>] = [...] let disposable = publisher.bind(to: observers)
-
bind(to ObserverType?)
Can bind optional type if ovserver is nil, it will ignore subscribe
let publisher = PublishSubject<String>() let observer: PublishSubject<String>? = nil let disposable = publisher.bind(to: observer)
-
RxCocoa
-
SharedSequenceConvertibleType
-
withLatestFrom
Extend withLatestFrom for support multi parameters
let a = SharedSequenceConvertibleType.just("A") let b = SharedSequenceConvertibleType.just("B") let c = SharedSequenceConvertibleType.just("C") SharedSequenceConvertibleType().withLatestFrom(a, b, c) .subscribe(onNext: { (a, b, c) in ... })
-
withLatestFromAndSelf
Extend withLatestFromAndSelf for combining parameters with self
let a = SharedSequenceConvertibleType.just("A") let b = SharedSequenceConvertibleType.just("B") let c = SharedSequenceConvertibleType.just("C") SharedSequenceConvertibleType().withLatestFromAndSelf(a, b, c) .subscribe(onNext: { (a, b, c) in ... })
-
-
Using CocoaPods:
pod 'RxSwiftExtensions'
RxSwiftExtensions is available under the MIT License See the LICENSE file for more info.