RxSwift篇章
RxSwift简介
RxSwift 是 ReactiveX 家族的重要一员, ReactiveX 是 Reactive Extensions 的缩写,一般简写为 Rx。ReactiveX 官方给Rx的定义是:Rx是一个使用可观察数据流进行异步编程的编程接口。
**致意:**ReactiveX 不仅仅是一个编程接口,它是一种编程思想的突破,它影响了许多其它的程序库和框架以及编程语言。它拓展了观察者模式,使你能够自由组合多个异步事件,而不需要去关心线程,同步,线程安全,并发数据以及I/O阻塞。
RxSwift试用
1.button事件
func setupButton() {
self.button.rx.tap.subscribe(onNext: { () in
print("点击来了")
})
.disposed(by: disposeBag)
}
2.textFiled输入
func setupTextFiled() {
//输入变化
self.textFiled.rx.text.orEmpty.changed
.subscribe(onNext: { (text) in
print(text)
})
.disposed(by: disposeBag)
//文本绑定到按钮
self.textFiled.rx.text
.bind(to: self.button.rx.title())
.disposed(by: disposeBag)
}
3.scrollView contentOffset
func setupScrollerView() {
scrollView.rx.contentOffset
.subscribe(onNext: { [weak self](content) in
self?.view.backgroundColor = UIColor.init(red: content.y/255*0.8, green: content.y/255*0.6, blue: content.y/255*0.3, alpha: 1)
})
.disposed(by: disposeBag)
}
4.手势
func setupGestureRecognizer(){
let tap = UITapGestureRecognizer()
self.label.addGestureRecognizer(tap)
self.label.isUserInteractionEnabled = true
tap.rx.event
.subscribe(onNext: { (tap) in
print(tap)
})
.disposed(by: disposeBag)
}
5.timer
func setupTimer() {
timer = Observable.interval(1, scheduler: MainScheduler.instance)
timer.subscribe { (num) in
print(num)
}.disposed(by: disposeBag)
}
6.KVO
func setupKVO() {
self.person.rx.observeWeakly(String.self, "name")
.subscribe (onNext:{ (value) in
print(value ?? "err")
})
.disposed(by: disposeBag)
}
7.通知
func setupNotification(){
NotificationCenter.default.rx.notification(UIResponder.keyboardWillShowNotification)
.subscribe { (notice) in
print(notice)
}
.disposed(by: disposeBag)
}
RxSwift优势
- RxSwift使得代码复用性较强,减少代码量.
- RxSwift因为声明都是不可变更,增加代码可读性.
- RxSwift使得更易于理解业务代码,抽象异步编程,统一代码风格.
- RxSwift使得代码更易于编写集成单元测试,增加代码稳定性.