Front-end
Apple
Apple
  • 第三方库
    • RAC库
      • ReactiveObjc
        • 如何实现的
        • 有关类
        • 有关协议
        • 关键概念列表
          • RACSignal有关类
            • RACStream
              • 头文件定义
            • RACSignal
              • 头文件定义内容
              • 核心代码
              • 常用的方法
                • concat:
                • bind:
                • zipWith 和merge
            • RACSubject
              • 内容
            • RACReplaySubject
              • 内容
            • RACBehaviorSubject
              • 内容
            • RACGroupedSignal
              • 内容
            • RACDynamicSignal
              • RACDynamicSignal
              • RACSignal vs RACDynamicSignal
            • RACReturnSignal
              • 内容
            • RACErrorSignal
            • RACEmptySignal
            • RACChannelTerminal
            • 疑问
              • RACChannelTerminal vs RACSubject
              • RACSignal vs RACStream
              • 热信号和冷信号
                • 进一步理解
              • 信号的发送者和接受者
                • RACSignal 不是信号对象么?为什么信号的发送者是自己呢?
          • RACChannel有关类
            • RACChannel
              • Page 1
              • 用于MVVM架构
              • RAC() vs RACChannelTo()
            • RACKVOChannel
              • 内容
              • 封装了系统的KVO
          • RACCommand
          • RACSubscriber
          • RACTuple
          • RACSequence有关类
          • RACKVOTrampoline
            • NSObject+RACKVOWrapper.h
            • NSObject+RACKVOWrapper.m
          • Page
          • 宏
          • 疑问
            • RACCommand vs RACSignal
            • 有了信号量,为什么还需要RACCommand
        • 操作方法
          • reduce
            • reduce 在不同语言以及库中是否一样的概念?
      • ReactiveSwift
        • 相比ReactiveObjc
      • RxSwift
      • Combine
      • 疑问
        • 热信号 vs 冷信号
        • ReactiveObjC 和 ReactiveSwift 实现原理差异
        • ReactiveObjC、ReactiveCocoa、ReactiveSwift的关系与区别
        • ReactiveObjC、ReactiveCocoa、ReactiveSwift内容
        • ReactiveSwift vs RxSwift
        • RxSwift、ReactiveSwift 和 ReactiveObjC
        • RxSwift、ReactiveSwift 、Combine
    • swift源码
      • 编译
        • 命令参数解释
        • 涉及到的工具
          • cmake 和 ninja
          • sccache
        • Rosetta模式
        • 遇到问题
          • FETCH_HEAD': Permission denied
          • --local_compiler_build': No such file or directory
          • ld: unsupported tapi file type '!tapi-tbd' in YAML file
          • python --version 显示没有这个命令
          • ModuleNotFoundError: No module named 'packaging'
          • ModuleNotFoundError: No module named 'sphinx'
            • sphinx是什么
          • ERROR: Could not find a version that satisfies the requirement sphinx (from versions: none)
          • /Applications/Python\ 3.x/Install\ Certificates.command 失败
          • 已经安装了sphinx,还是显示错误
      • 涉及到的知识点
        • Swift中的MCCAS
Powered by GitBook
On this page
  1. 第三方库
  2. RAC库
  3. ReactiveObjc
  4. 关键概念列表

RACCommand

RACCommand 是 ReactiveObjC 中专门用于封装事件(例如按钮点击、网络请求等)的类。它以响应式编程的方式来执行和管理这些事件,并用 RACSignal 传递结果或状态信息。与普通的信号不同,RACCommand 专注于“事件驱动”场景,并提供了执行状态控制、错误处理和信号管理等功能。

RACCommand 的作用

  1. 封装事件逻辑:RACCommand 用于封装如按钮点击、网络请求等动作,统一管理这些事件的执行和响应。

  2. 状态管理:RACCommand 提供 enabled 属性来控制是否可执行,executing 信号来管理执行状态。

  3. 结果和错误处理:通过 executionSignals 监听执行的结果和 errors 信号处理错误。

RACCommand 的核心属性和方法

  1. initWithSignalBlock:

    • signalBlock 是一个返回 RACSignal 的闭包。每次 RACCommand 执行时都会调用该闭包来生成一个新的 RACSignal,用于表示动作的执行过程和结果。

  2. enabled 属性

    • enabled 是一个信号,表示 RACCommand 是否可以执行。可以动态地控制条件,以便在满足特定条件下才允许执行。

  3. executionSignals

    • executionSignals 是一个信号的信号,即 RACSignal<RACSignal *>。每次 RACCommand 执行时,都会发送一个新的执行信号。我们可以通过订阅 executionSignals 来获取执行的每个信号,或者使用 switchToLatest 获取最新的信号。

  4. executing 信号

    • executing 信号在 RACCommand 执行时发出 YES,执行完成时发出 NO,通常用于显示加载指示器。

  5. errors 信号

    • errors 是一个信号,专门用于发出命令执行过程中产生的错误。可以用于集中处理错误情况。

RACCommand 的使用示例

以下示例展示了如何使用 RACCommand 来管理登录请求,并处理执行状态和错误:

// 创建 RACCommand,并定义 signalBlock 来返回执行信号
self.loginCommand = [[RACCommand alloc] initWithEnabled:canExecuteSignal signalBlock:^RACSignal *(id input) {
    // 模拟一个登录请求信号
    return [self loginSignal];
}];

// 监听执行结果
[self.loginCommand.executionSignals.switchToLatest subscribeNext:^(id result) {
    NSLog(@"登录成功,返回结果:%@", result);
}];

// 错误处理
[self.loginCommand.errors subscribeNext:^(NSError *error) {
    NSLog(@"登录失败,错误:%@", error);
}];

// 设置按钮点击事件
self.loginButton.rac_command = self.loginCommand;

代码解析

  • initWithEnabled:signalBlock::RACCommand 初始化时传入了 enabled 条件和 signalBlock,确保按钮只有在 canExecuteSignal 为 YES 时才可以点击。

  • executionSignals.switchToLatest:executionSignals 会发送每次执行产生的信号,通过 switchToLatest 获取最新执行结果。

  • errors:若请求过程中出现错误,errors 信号会将错误发出,方便集中处理。

使用场景

  • UI 控件事件:比如将按钮的点击操作绑定到 RACCommand,通过 RACCommand 统一管理事件触发和处理。

  • 网络请求或异步任务:将请求封装到 RACCommand 中,通过 executionSignals 和 errors 处理结果或错误。

  • 控制执行状态:通过 enabled 控制命令是否可用,并通过 executing 控制任务执行时的加载动画等。

总结

  • RACCommand 封装了动作的执行逻辑,使得事件触发、执行状态和结果处理都在一个类中进行统一管理。

  • RACCommand 中的每个执行都会生成一个 RACSignal,将结果和状态传递给观察者。

  • 通过 executionSignals 和 errors 进行结果和错误的监听,适合需要动态控制执行的场景。

这样可以让事件驱动的代码更加模块化,也便于管理 UI 交互与后台操作的关系,使代码更加简洁和维护性更高。

Previous封装了系统的KVONextRACSubscriber

Last updated 8 months ago