初识RxSwift初识RxSwift

简介: 初识RxSwift

1. 函数式编程(Functional Programming,简称FP)

主要思想是把函数看做是“第一等公民”,函数与其他数据类型一样,可以赋值给其他变量,也可以作为函数的参数,以及函数的返回值,类似于下面这样

func sum(_ a: Int, _ b: Int) -> Int { a + b }
func sub(_ a: Int, _ b: Int) -> Int { a - b }
print(sum(sub(20, 10), sub(40, 20)))//10 + 20 = 30

2. 响应式编程(Rective Programming,简称RP)

主要是为了简化异步编程,提供一种更优雅的数据绑定,一般与函数式结合在一起,所以也会叫做函数响应式编程(Functional Rective Programming,简称FRP)

有人这样理解函数响应式编程,比如c = a + b,变量c为变量a与变量b的和,当执行完这条语句之后,当我们再次改变变量a或者变量b的值的时候,c不会变化,而函数响应式编程就是为了实现当变量a或变量b变化的时候,变量c也跟着变化的。


3. 响应式编程框架

ReactiveCocoa(RAC):有OC和Swift两个版本

ReactiveX:有很多语言的版本,比如RxJava,RxJS,RxPHP,RXSwift,RxKotlin等,其中RxSwift(RectiveX for Swift),为RectiveX的Swift版本;

RxSwift:RectiveX标准API的Swift实现,不包括iOS相关的任何内容

RxCocoa:基于RxSwift,给iOS的UI控件扩展了很多Rx特性


4. RxSwift常用事件回调

iOS中的回调方式有非常多的种类,UIKit主要进行的事件处理Target-ActiondelegateBlockNotifcationCenterKVO监听。而原生开发中,触发对象与响应方法是分离的,如UIButton的初始化和点击响应方法是分离的。RxSwift恰好能以统一的形式来解决跨类调用的问题,也包装了UIKit事件处理、NotifcationCenterKVO等常见的场景,让代码整合的更加统一。


01. 按钮点击

let button = UIButton(type: .custom)
button.frame = CGRect(x: 100, y: 100, width: 100, height: 100)
button.backgroundColor = .red
view.addSubview(button)
button.rx.tap.subscribe(onNext: {
    print("button click")
}).disposed(by: disposeBag)
let button = UIButton(type: .custom)
button.frame = CGRect(x: 100, y: 100, width: 100, height: 100)
button.backgroundColor = .red
view.addSubview(button)
button.rx.tap.subscribe(onNext: {
    print("button click")
}).disposed(by: disposeBag)


02. 手势

let tap = UITapGestureRecognizer()
view.addGestureRecognizer(tap)
tap.rx.event.subscribe {
    print("gesture click ", $0)
}.disposed(by: disposeBag)
let tap = UITapGestureRecognizer()
view.addGestureRecognizer(tap)
tap.rx.event.subscribe {
    print("gesture click ", $0)
}.disposed(by: disposeBag)


03. 文本输入监听

let textField = UITextField(frame: CGRect(x: 200, y: 100, width: 101, height: 100))
textField.borderStyle = .line
view.addSubview(textField)
textField.rx.text.orEmpty.changed.throttle(.milliseconds(100), scheduler: MainScheduler.instance).subscribe { (text) in
    print(text)
}.disposed(by: disposeBag)
let textField = UITextField(frame: CGRect(x: 200, y: 100, width: 101, height: 100))
textField.borderStyle = .line
view.addSubview(textField)
textField.rx.text.orEmpty.changed.throttle(.milliseconds(100), scheduler: MainScheduler.instance).subscribe { (text) in
    print(text)
}.disposed(by: disposeBag)


04. 代理监听


view.addSubview(scrollView)
scrollView.rx.didScroll.subscribe {[weak scrollView] _ in
    print("开始滚动了 - ", scrollView?.contentOffset.y ?? 0)
}.disposed(by: disposeBag)
scrollView.rx.contentOffset.subscribe {
    print("contentOffset - ", $0.y)
}.disposed(by: disposeBag)
view.addSubview(scrollView)
scrollView.rx.didScroll.subscribe {[weak scrollView] _ in
    print("开始滚动了 - ", scrollView?.contentOffset.y ?? 0)
}.disposed(by: disposeBag)
scrollView.rx.contentOffset.subscribe {
    print("contentOffset - ", $0.y)
}.disposed(by: disposeBag)


05. KVO

scrollView.rx.observeWeakly(CGPoint.self, "contentOffset").subscribe { (value) in
    print("kvo - contentOffset - ", value)
}.disposed(by: disposeBag)
scrollView.rx.observeWeakly(CGPoint.self, "contentOffset").subscribe { (value) in
    print("kvo - contentOffset - ", value)
}.disposed(by: disposeBag)


06. 通知

NotificationCenter.default.rx.notification(UIApplication.willEnterForegroundNotification).subscribe { (_) in
    print("进入前台")
}.disposed(by: disposeBag)
NotificationCenter.default.rx.notification(UIApplication.didEnterBackgroundNotification).subscribe { (_) in
    print("进入后台")
}.disposed(by: disposeBag)


07. 网络回调

URLSession.shared.rx.response(request: URLRequest(url: URL(string: "https://www.baidu.com")!)).subscribe { (resp, data) in
    print("响应结果code ->", resp.statusCode, "data.count ->", data.count)
}.disposed(by: disposeBag)


08. 定时器

Observable<Int>.interval(.seconds(1), scheduler: MainScheduler.instance).subscribe(onNext: { (res) in
    print(res)
}).disposed(by: disposeBag)
Observable<Int>.interval(.seconds(1), scheduler: MainScheduler.instance).subscribe(onNext: { (res) in
    print(res)
}).disposed(by: disposeBag)

还有更多控件的使用监听回调,如UITextViewUITableViewUISegmentedControlUISearchBar等UI控件均可监听,具体可查看RxSwift、RxCocoa源码。

1. 函数式编程(Functional Programming,简称FP)

主要思想是把函数看做是“第一等公民”,函数与其他数据类型一样,可以赋值给其他变量,也可以作为函数的参数,以及函数的返回值,类似于下面这样


func sum(_ a: Int, _ b: Int) -> Int { a + b }
func sub(_ a: Int, _ b: Int) -> Int { a - b }
print(sum(sub(20, 10), sub(40, 20)))//10 + 20 = 30
func sum(_ a: Int, _ b: Int) -> Int { a + b }
func sub(_ a: Int, _ b: Int) -> Int { a - b }
print(sum(sub(20, 10), sub(40, 20)))//10 + 20 = 30

2. 响应式编程(Rective Programming,简称RP)

主要是为了简化异步编程,提供一种更优雅的数据绑定,一般与函数式结合在一起,所以也会叫做函数响应式编程(Functional Rective Programming,简称FRP)

有人这样理解函数响应式编程,比如c = a + b,变量c为变量a与变量b的和,当执行完这条语句之后,当我们再次改变变量a或者变量b的值的时候,c不会变化,而函数响应式编程就是为了实现当变量a或变量b变化的时候,变量c也跟着变化的。


3. 响应式编程框架

ReactiveCocoa(RAC):有OC和Swift两个版本

ReactiveX:有很多语言的版本,比如RxJava,RxJS,RxPHP,RXSwift,RxKotlin等,其中RxSwift(RectiveX for Swift),为RectiveX的Swift版本;

RxSwift:RectiveX标准API的Swift实现,不包括iOS相关的任何内容

RxCocoa:基于RxSwift,给iOS的UI控件扩展了很多Rx特性


4. RxSwift常用事件回调

iOS中的回调方式有非常多的种类,UIKit主要进行的事件处理Target-ActiondelegateBlockNotifcationCenterKVO监听。而原生开发中,触发对象与响应方法是分离的,如UIButton的初始化和点击响应方法是分离的。RxSwift恰好能以统一的形式来解决跨类调用的问题,也包装了UIKit事件处理、NotifcationCenterKVO等常见的场景,让代码整合的更加统一。


01. 按钮点击

let button = UIButton(type: .custom)
button.frame = CGRect(x: 100, y: 100, width: 100, height: 100)
button.backgroundColor = .red
view.addSubview(button)
button.rx.tap.subscribe(onNext: {
    print("button click")
}).disposed(by: disposeBag)


02. 手势

let tap = UITapGestureRecognizer()
view.addGestureRecognizer(tap)
tap.rx.event.subscribe {
    print("gesture click ", $0)
}.disposed(by: disposeBag)
let tap = UITapGestureRecognizer()
view.addGestureRecognizer(tap)
tap.rx.event.subscribe {
    print("gesture click ", $0)
}.disposed(by: disposeBag)


03. 文本输入监听

let textField = UITextField(frame: CGRect(x: 200, y: 100, width: 101, height: 100))
textField.borderStyle = .line
view.addSubview(textField)
textField.rx.text.orEmpty.changed.throttle(.milliseconds(100), scheduler: MainScheduler.instance).subscribe { (text) in
    print(text)
}.disposed(by: disposeBag)
let textField = UITextField(frame: CGRect(x: 200, y: 100, width: 101, height: 100))
textField.borderStyle = .line
view.addSubview(textField)
textField.rx.text.orEmpty.changed.throttle(.milliseconds(100), scheduler: MainScheduler.instance).subscribe { (text) in
    print(text)
}.disposed(by: disposeBag)


04. 代理监听

view.addSubview(scrollView)
scrollView.rx.didScroll.subscribe {[weak scrollView] _ in
    print("开始滚动了 - ", scrollView?.contentOffset.y ?? 0)
}.disposed(by: disposeBag)
scrollView.rx.contentOffset.subscribe {
    print("contentOffset - ", $0.y)
}.disposed(by: disposeBag)


05. KVO

scrollView.rx.observeWeakly(CGPoint.self, "contentOffset").subscribe { (value) in
    print("kvo - contentOffset - ", value)
}.disposed(by: disposeBag)


06. 通知

NotificationCenter.default.rx.notification(UIApplication.willEnterForegroundNotification).subscribe { (_) in
    print("进入前台")
}.disposed(by: disposeBag)
NotificationCenter.default.rx.notification(UIApplication.didEnterBackgroundNotification).subscribe { (_) in
    print("进入后台")
}.disposed(by: disposeBag)


07. 网络回调

URLSession.shared.rx.response(request: URLRequest(url: URL(string: "https://www.baidu.com")!)).subscribe { (resp, data) in
    print("响应结果code ->", resp.statusCode, "data.count ->", data.count)
}.disposed(by: disposeBag)
URLSession.shared.rx.response(request: URLRequest(url: URL(string: "https://www.baidu.com")!)).subscribe { (resp, data) in
    print("响应结果code ->", resp.statusCode, "data.count ->", data.count)
}.disposed(by: disposeBag)


08. 定时器

Observable<Int>.interval(.seconds(1), scheduler: MainScheduler.instance).subscribe(onNext: { (res) in
    print(res)
}).disposed(by: disposeBag)

还有更多控件的使用监听回调,如UITextViewUITableViewUISegmentedControlUISearchBar等UI控件均可监听,具体可查看RxSwift、RxCocoa源码。

相关文章
|
设计模式 安全
如何用C++11实现观察者模式
观察者模式是一种设计模式,定义了对象之间的一对多关系。当一个对象状态发生改变时,它的依赖者都会收到通知并自动更新。在C++11中,可以通过以下方式实现观察者模式:
108 0
|
9月前
|
安全 Swift iOS开发
【Swift开发专栏】Swift中的属性观察者与KVO
【4月更文挑战第30天】Swift编程语言支持属性观察者(`willSet`和`didSet`)和键值观察(KVO)来响应属性变化。属性观察者在设置前(`willSet`)和设置后(`didSet`)执行代码,可用于数据绑定。KVO是Cocoa/Cocoa Touch中的机制,需`NSObject`子类和`@objc dynamic`属性配合使用。注意在观察者销毁前移除观察,以避免内存问题。示例展示了属性观察者实现简单数据绑定。
133 1
|
前端开发
RxSwift-双向绑定
RxSwift-双向绑定
317 0
|
设计模式 测试技术
【坦克大战一】——简单实现小结
小时候对于游戏的痴迷让我对于游戏有一种心底的渴望,然而随着时间的推移阅历、经历的增加以及现在从事的编程行业似乎和游戏越来越远;在工作中对技术的要求以及未来技术的分量加上一次偶然的机会重新燃起我对游戏的渴望,不过这次的游戏并不仅仅是痴迷,而是让自己拥有一颗归零的心态在游戏编程的角度去学习那些基础的知识。
|
设计模式
大话设计模式行为型总结导图
大话设计模式行为型总结导图
探秘 RxJS Observable 为什么要长成这个样子?!
我们都知道 RxJS Observable 最基础的使用方法:是建立 Observable,即调用 .create API
|
Android开发 索引
EventBus封装到项目架构|青训营笔记
封装该库到自己的项目的目的有两个 便捷绑定和解绑 EventBus 便捷通过 EventBus 发送消息和处理消息 代码美观
EventBus封装到项目架构|青训营笔记
|
缓存 监控 Swift
函数式编程框架 ReactiveCocoa 基础入门
函数式编程框架 ReactiveCocoa 基础入门
156 0
|
缓存 前端开发 API
ReactiveCocoa 进阶,轻松搞定函数式编程框架
函数式编程已经变得越来越流行,而且也有很大的优势,作为iOS开发者,函数式编程框架**ReactiveCocoa**到底怎么使用呢, 接下来我们来深入介绍**ReactiveCocoa**及其在**MVVM**中的用法。
209 0
|
JavaScript
手写代码:实现一个EventBus
EventBus,事件总线。总线一词来自于《计算机组成原理》中的”系统总线“,是指用于连接多个部件的信息传输线,各部件共享的传输介质。我们通常把事件总线也成为自定义事件,一般包含`on`、`once`、`emit`、`off`等方法。在Vue2中想要实现EventBus比较简单,直接暴露出一个`new Vue()`实例即可,以此为思路,我们应该如何自定义实现EventBus呢?
546 0
手写代码:实现一个EventBus

热门文章

最新文章