🚄 发布路线图
入门
了解ReactiveSwift中的**核心响应式原语,以及这些原语提供的基本操作符**。
扩展模块
模块 | 仓库 | 描述 |
---|---|---|
ReactiveCocoa |
ReactiveCocoa/ReactiveCocoa
| 使用ReactiveSwift绑定和扩展来扩展Cocoa框架和Objective-C运行时API。 |
Loop |
ReactiveCocoa/Loop
| 使用ReactiveSwift实现可组合的单向数据流。 |
ReactiveSwift Composable Architecture |
trading-point/reactiveswift-composable-architecture
| 使用ReactiveSwift而不是Combine的Pointfree可组合架构。 |
ReactiveSwift简介
__ReactiveSwift__提供可组合、声明式和灵活的原语,这些原语围绕___随时间推移的值流___这一宏大概念构建。
这些原语可以用来统一表示常见的Cocoa和通用编程模式,这些模式本质上是一种观察行为,例如委托模式、回调闭包、通知、控制操作、响应链事件、futures/promises和键值观察 (KVO)。
由于所有这些不同的机制都可以以_相同_的方式表示,因此可以轻松地以声明式方式将它们组合在一起,减少混乱的代码和需要桥接的状态。
参考
-
ReactiveSwift原语的契约、ReactiveSwift的最佳实践以及实现自定义操作符的指南。
安装
ReactiveSwift支持macOS 10.13+、iOS 11.0+、watchOS 4.0+、tvOS 11.0+和Linux。
Carthage
如果您使用Carthage来管理依赖项,只需将ReactiveSwift添加到您的Cartfile
中:
github "ReactiveCocoa/ReactiveSwift" ~> 6.1
如果您使用Carthage构建依赖项,请确保已将ReactiveSwift.framework
添加到目标的"Linked Frameworks and Libraries"部分,并将其包含在Carthage框架复制构建阶段中。
CocoaPods
如果您使用CocoaPods来管理依赖项,只需将ReactiveSwift添加到您的Podfile
中:
pod 'ReactiveSwift', '~> 6.1'
Swift Package Manager
如果您使用Swift Package Manager,只需在Package.swift
中将ReactiveSwift添加为包的依赖项:
.package(url: "https://github.com/ReactiveCocoa/ReactiveSwift.git", from: "6.1.0")
Git子模块
- 将ReactiveSwift仓库作为应用程序仓库的子模块添加。
- 在ReactiveSwift文件夹中运行
git submodule update --init --recursive
。 - 将
ReactiveSwift.xcodeproj
拖放到应用程序的Xcode项目或工作空间中。 - 在应用程序目标设置的"General"选项卡中,将
ReactiveSwift.framework
添加到"Embedded Binaries"部分。 - 如果应用程序目标不包含任何Swift代码,还应将
EMBEDDED_CONTENT_CONTAINS_SWIFT
构建设置设置为"Yes"。
操场
我们还提供了一个Playground,以便您熟悉ReactiveCocoa的操作符。要开始使用它:
- 克隆ReactiveSwift仓库。
- 使用以下终端命令之一从ReactiveSwift项目根目录检索项目依赖项:
git submodule update --init --recursive
或者,如果您安装了Carthagecarthage checkout
- 打开
ReactiveSwift.xcworkspace
- 构建
ReactiveSwift-macOS
方案 - 最后打开
ReactiveSwift.playground
- 选择
View > Show Debug Area
有问题吗?
如果您需要任何帮助,请访问我们的GitHub问题或Stack Overflow。如果您在归档中找不到任何解决方案,请随时提出问题。
发布路线图
记录计划
ABI稳定性发布
ReactiveSwift目前没有计划声明ABI和模块稳定性。在可预见的未来,它将继续作为仅源代码依赖项提供。