ReactiveCocoa 3.0 简介

RAC3创建Signal

项目中添加ReactiveCocoa最简单的方式是使用Carthage,创建如下的Cartfile即可:

github "ReactiveCocoa/ReactiveCocoa" "v3.0-beta.1"

在项目路径下执行carthage update

ReactiveCocoa3.0包含全新的Swift-API,同时也支持Objective-C,详情参考Change Log。ReactiveCocoa3.0存在两种不同类型的Signal,一种是旧的Obj-C风格的RACSignal,另一种是新的Swift风格的Signal.
Swift版signal有一个非常重要的功能是使用的泛型

class Signal<T, E: ErrorType> { 
  ...
}

类型参数T表示signal发出的next事件所带的参数类型,参数E表示signal发出的error事件所带的参数类型,并且必须实现ErrorType协议。
创建Swift版signal和Objective-C版的方式类型。如下是创建一个信号,每秒会发送一个next事件

    func createSignal() -> Signal<String, NSError> {
        var count = 0
        return Signal {
            sink in
            NSTimer.schedule(repeatInterval: 1.0) {
                timer in
                sink.sendNext("tick#\(count++)")
            }
            return nil
        }
    }

Signal的构造函数参数是一个generator:ReactiveCocoa.Observer<Value, Error>,这里使用闭包来构造一个Observer传入Signal的构造函数。闭包中传入的参数就是之前传入的Observer


Signal会将事件发送给sink

其中NSTimer.schedule是扩展方法,详情请见NSTimer+Closure.swift

观察Singal

有多种方式来观察或者订阅signal。最简单的方式是使用observe方法
下面是使用observe观察signal

let signal = createSignal()
signal.observeNext{print($0)}

输出:

tick #0
tick #1
tick #2
tick #3
tick #4

另一种方式,可以提供一个观察signal发送事件的对象

createSignal().observe({
   event in
   switch event {
         case let .Next(data):
             print(data)
         default:
             break
   }
})

闭包中的eventEvent类型,该类型是一个枚举类型

public enum Event<Value, Error : ErrorType> {
    /// A value provided by the signal.
    case Next(Value)
    /// The signal terminated because of an error. No further events will be
    /// received.
    case Failed(Error)
    /// The signal successfully terminated. No further events will be received.
    case Completed
    /// Event production on the signal has been interrupted. No further events
    /// will be received.
    case Interrupted
    /// Whether this event indicates signal termination (i.e., that no further
    /// events will be received).
    public var isTerminating: Bool { get }
    /// Lifts the given function over the event's value.
    public func map<U>(f: Value -> U) -> ReactiveCocoa.Event<U, Error>
    /// Lifts the given function over the event's error.
    public func mapError<F>(f: Error -> F) -> ReactiveCocoa.Event<Value, F>
    /// Unwraps the contained `Next` value.
    public var value: Value? { get }
    /// Unwraps the contained `Error` value.
    public var error: Error? { get }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一个信号,由Signal类型表现,是可以被持续监视的一系列事件(events)。 信号一般用来表示“正在进行中”的...
    HetfieldJoe阅读 10,197评论 16 21
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,313评论 4 61
  • 你我相遇是缘,那一年我为你心动,我说不出口!写下博文期待你看见,让你懂我的心。 我习惯了慢生活的节奏,也让我无法鼓...
    路过你的心阅读 1,761评论 0 0
  • 在项目中,美工给的图都是6p,字体也是按照6p的尺寸给的,我是使用代码设置的字体,在5,6上面字体都可以接受,但是...
    x_JANG阅读 4,728评论 0 5