RxSwift笔记:RxSwift简介及入门

我们在使用UIKit种遇到的问题

  • 获得网络数据后需要手动刷新UI
  • 在修改/新加数据时漏加错加状态导致UI异常
  • 用户事件导致界面显示异常并难以追踪复现

函数式编程 响应式编程 函数响应式编程

函数式编程

主要思想是把运算过程尽量写成一系列嵌套的函数调用, 它需要我们将函数作为参数传递,或者作为返回值返还。我们可以通过组合不同的函数来得到想要的结果

self.text = text;
self.color = color;

extension UITextField {
    func rx_text(text : String) -> () -> UITextField {
        return {
            self.text = text
            return self
        }
    }
    
    func rx_color(color : UIColor) -> () -> UITextField {
        return {
            self.textColor = color
            return self
        }
    }
}

var textFiled = UITextField.init()
textFiled.rx_text(text: "aaa")().rx_color(color: .red)()

响应式编程

响应式编程(reactive programming)是一种基于数据流(data stream)和变化传递(propagation of change)的声明式(declarative)的编程范式。

var a = 3
var b = 4
var result = 0;

class Binder {
    
    func updateResult() {
        result = a + b
        print(result)
    }
}

    var binder = Binder();
    a = 5
    binder.updateResult();  //result = 9
    b = 6
    binder.updateResult(); //result = 11


extension Binder {
    func bindingValue( first : inout Int, second : inout Int) {
        //make c always equal a and b
    }
}

    binder.bindingValue(first: &a, second: &b) // result = 11
    b = 5 // result = 10
    a = 4 // result = 9

函数响应式编程

函数式负责序列操作,响应式负责监听变化,响应这个序列。当然这个序列是具备着特别的封装(异步等)
我们通过不同的构建函数,来创建所需要的数据序列。最后通过适当的方式来响应这个序列。这就是函数响应式编程。

extension Binder {
    func bindingValueRx( first : inout Int, second : inout Int) -> (String) -> Binder  {
        return { output in
            // binding a and b to result
            print(output)
            return self
        }
    }
    func unbindingValueRx( first : inout Int, second : inout Int) -> () -> Binder  {
        return {
            //unbindg a and b to result
            return self
        }
    }
}

binder.bindingValueRx(first: &a, second: &b)("finished").unbindingValueRx(first: &a, second: &b)()

RxSwift & RxCocoa

  • RxSwift
    Microsoft 的一个团队接受了解决我们在本章中讨论过的异步、可扩展、实时应用程序开发问题的挑战。大约在 2009 年的某个时候,他们提供了一个名为 Reactive Extensions for .NET (Rx) 的新客户端和服务器端框架。Rx for .NET 自 2012 年以来一直是开源的,允许其他语言和平台重新实现相同的功能,这将 Rx 变成了跨平台标准。今天,您拥有 RxJS、RxKotlin、Rx.NET、RxScala、RxSwift 等等。基于响应式扩展规范,所有人都努力实现相同的行为和相同的表达 API。最终,使用 RxSwift 创建 iOS 应用程序的开发人员可以在网络上与其他使用 RxJS 的程序员自由讨论应用程序逻辑。
  • RxCocoa
    RxCocoa 是 RxSwift 的配套库,包含所有专门帮助 UIKit 和 Cocoa 开发的类。除了具有一些高级类之外,RxCocoa 还为许多 UI 组件添加了响应式扩展,以便您可以开箱即用地订阅各种 UI 事件。
toggleSwitch.rx.isOn
  .subscribe(onNext: { isOn in
    print(isOn ? "It's ON" : "It's OFF")
  })
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,192评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,858评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,517评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,148评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,162评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,905评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,537评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,439评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,956评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,083评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,218评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,899评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,565评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,093评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,201评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,539评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,215评论 2 358

推荐阅读更多精彩内容