zoukankan      html  css  js  c++  java
  • iOS开发--Swift RAC响应式编程初探

      时间不是很充足, 先少说点, RAC的好处是响应式编程, 不需要自己去设置代理委托, target, 而是主要以信息流(signal), block为主, 看到这里激动吧, 它可以帮你监听你的事件, 并通过回调(callback)的形式, 实时更新UI。 其实就是把action, 观察者模式(kvo)加上block, 代理等封装起来统一了接口。上面这句话等同于放屁,请别认真,那时候太菜,根本是啥也不懂,这是一种FRP编程范式,准确说也就是通过block(OC),闭包(Swift)实现了一个Monad,再深入也就是统筹学的概念了,原谅我也不是很懂,是一种将数学理论实现在了编程范式中的实际应用,希望有一天我能更加清楚函子(Fountor),单子(Monad)等概念,再写出来给自己分析温习。

      这篇文章就不太针对RAC事件流的初学者了, 希望大家有一些OC的基础, 或者看过OC的应用却苦于找不到Swift宏接口的同学, 我的博客一般都是针对OC转Swift的开发者, 所以这里就简单的写几句先, 以后我再补全加上demo.

      在OC中RAC使用时用的是个宏, 然后骂娘的大家都知道Swift取消了宏, 所以假如你习惯了RAC(Rx完全支持swift), 想要使用的话, 自己新建一个文件, 然后加入如下代码就可以了.

      不过吧Swift其实是不希望我们这么用的,而是如同RxJava,或者是RxJS等生成一个Observe对象来具体操作,不过这里也不再赘述了,OC用习惯了,先这么写,嘿嘿嘿。

    public struct RAC  {

        var target : NSObject!

        var keyPath : String!

        var nilValue : AnyObject!

        init(_ target: NSObject!, _ keyPath: String, nilValue: AnyObject? = nil) {

            self.target = target

            self.keyPath = keyPath

            self.nilValue = nilValue

        }

        

        func assignSignal(signal : RACSignal) {

            signal.setKeyPath(self.keyPath, onObject: self.target, nilValue: self.nilValue)

        }

    }

    func RACObserve(target: NSObject!, keyPath: String) -> RACSignal  {

        return target.rac_valuesForKeyPath(keyPath, observer: target)

    }

    infix operator <~ {}

    func <~ (rac: RAC, signal: RACSignal){

        return rac.assignSignal(signal)

    }

      好久没写了,过来更新下,添加了过去OC版本的RACObserve宏的实现函数,又做了一个运算符重载,相信能有效解决OC转Swift同学的疑惑,这里提一两个Swift需要注意的点,RAC同学要注意的。

      1,Swift默认是静态语言,所以对于像过去我们要监听一个对象的特定属性,触发setter等方式都无效,不会生成对应信号,只能手动的KVC,也就是setValue(for:keyPath)函数才可以生成信号,这是极不方便的,所以请看第二条。

      2,苹果允许我们对一个对象特定的属性使用dynamic(动态)关键字进行修饰,这样当对一个值进行setter的时候就可以成功触发,貌似Swift4会为Swift增加动态特性,希望苹果能够更加给力,至少目前而言想要写一些运行时函数还是非常麻烦的,只能桥接OC的runtime模块代码。

      

  • 相关阅读:
    Java并发容器总结
    ReentrantLock源码分析
    webpack插件之webpack-dev-server
    webpack插件之htmlWebpackPlugin
    webpack配置之webpack.config.js文件配置
    webpack的安装和运行
    webpack安装大于4.x版本(没有配置webpack.config.js)
    webpack安装低于4版本(没有配置webpack.config.js)
    什么是webpack以及为什么使用它
    webpack前置知识2(JavaScript项目初始化)
  • 原文地址:https://www.cnblogs.com/JianweiWang/p/5245323.html
Copyright © 2011-2022 走看看