函数响应式编程
一:函数式
函数式编程简称FP(Functional Programming),函数式编程就是一种抽象程度很高的编程范式,它将计算机运算看做是数学中函数的计算,而纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用。而允许使用变量的程序设计语言,由于函数内部的变量状态不确定,同样的输入,可能得到不同的输出,因此,这种函数是有副作用的。
函数式编程的一个特点就是:允许把函数本身作为参数传入另一个函数,同时还允许返回一个函数!
函数表达式: y = f(x) ---> x = f(x) ---> y = f(f(x))
常规需求例子,感受函数式的舒服!
- 对于数组 [1,2,3,4,5,6,7,8,9,10],首先获取 > 2 的数字,然后获取的数字+1,再输出所有数字之中的偶数
let array = [1,2,3,4,5,6,7,8,9,10]
for num in array{
if num > 2{
let number = num + 1
if (number % 2 == 0) {
print(number)
}
}
}
- 上面的代码嵌套层次之深,代码过多
- 代码的可读性也是非常差的
- 代码复用性较低
- 维护以及代码构建成本太高,这样就成了函数式出现的必要性
let array = [1,2,3,4,5,6,7,8,9,10]
array.filter{ $0 > 2}
.filter{ ($0+1) % 2 == 0 }
.forEach { print($0) }
- 代码层次非常清晰
- 代码可读性高
- 代码复用性高
- 代码简洁
二:响应式
对象对某一数据流变化做出响应的这种编码方式称为响应式。例如你在某一个时刻订阅了一部小说,后面这个小说一有更新,我们随着时间也能自定接受推送,这就是响应
RxSwift使用
RxSwift对使用Swift的帮助有如下几点:
Swift为值类型,在传值与方法回调上有影响,RxSwift一定程度上弥补Swift的灵活性
- RxSwift使得代码复用性较强,减少代码量
- RxSwift因为声明都是不可变更,增加代码可读性
- RxSwift使得更易于理解业务代码,抽象异步编程,统一代码风格
- RxSwift使得代码更易于编写集成单元测试,增加代码稳定性
一:button点击事件
let disposeBag = DisposeBag()
//MARK: - RxSwift应用-button响应
func setupButton() {
// 传统事件
self.button.addTarget(self, action: #selector(didClickButton), for: .touchUpInside)
// Rx写法
self.button.rx.tap
.subscribe(onNext: { [weak self] in
print("点了btn")
self?.view.backgroundColor = UIColor.orange
})
.disposed(by: disposeBag)
self.button.rx.controlEvent(.touchUpOutside)
}
二:textfiled文本响应
//MARK: - RxSwift应用-textfiled
func setupTextFiled() {
// 我们如果要对输入的文本进行操作 - 比如输入的的内容 然后我们获取里面的偶数
// self.textFiled.delegate = self
// 下面我们来看看Rx
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)
}
三:scrollView使用
//MARK: - RxSwift应用-scrollView
func setupScrollerView() {
scrollView.rx.contentOffset.subscribe(onNext: { [weak self] (content) in
self?.view.backgroundColor = UIColor.init(red: content.y/255.0*0.8, green: content.y/255.0*0.3, blue: content.y/255.0*0.6, alpha: 1);
print(content.y)
}).disposed(by: disposeBag)
}
- 从上面三个UI效果来说,如果原生实现必将做很多恶心的处理:addTarget或者实现代理, 但是在RxSwift的世界里只需要一句代码,真是万物皆Rx
四:KVO
//MARK: - RxSwift应用-KVO
func setupKVO() {
// 系统KVO 还是比较麻烦的
// person.addObserver(self, forKeyPath: "name", options: .new, context: nil)
person.rx.observeWeakly(String.self, "name").subscribe(onNext: { (value) in
print(value as Any)
}).disposed(by: disposeBag)
}
- 原生KVO就需要三部曲,非常恶心,其实对于我们开发来说根本没必要!RxSwift还是一句代码搞定,牛逼!
五:通知
//MARK: - 通知
func setupNotification(){
NotificationCenter.default.rx
.notification(UIResponder.keyboardWillShowNotification)
.subscribe { (noti) in
print(noti)
}.disposed(by: disposeBag)
}
- 通知的实现,也是比较友善的:编程习惯都有在RxSwift风格里面保留
六:手势
//MARK: - 手势
func setupGestureRecognizer(){
let tap = UITapGestureRecognizer()
self.label.addGestureRecognizer(tap)
self.label.isUserInteractionEnabled = true
tap.rx.event.subscribe { (event) in
print(event.view)
}.disposed(by: disposeBag)
}
- 很多小伙伴可能会吐槽手势怎么不那么爽!其实你误解,RxSwift是实现的响应关系,本身手势也是需要添加事件对象的!
七:网络请求
func setupNextwork() {
let url = URL(string: "https://www.baidu.com")
URLSession.shared.rx.response(request: URLRequest(url: url!))
.subscribe(onNext: { (response, data) in
print("response ==== \(response)")
print("data ===== \(data)")
}, onError: { (error) in
print("error ===== \(error)")
}).disposed(by: disposeBag)
}
八:timer定时器
//MARK: - RxSwift应用-timer定时器
func setupTimer() {
timer = Observable<Int>.interval(1, scheduler: MainScheduler.instance)
timer.subscribe(onNext: { (num) in
print("hello word \(num)")
}).disposed(by: disposeBag)
}
- RxSwift实现的timer免去了我们计时器的一些不必要的麻烦
- runloop影响
- 销毁问题
- 线程问题
RxSwift无论从代码量,还是从代码的可读性,抑或代码的复用性......都是大大优化!让开发者抛弃更多的胶水代码,直面开发需求。
网友评论