RAC,ReactiveSwift
1.创建信号
// 1.通过信号发生器创建(冷信号)
let producer = SignalProducer<String, NoError>.init { (observer, _) in
print("新的订阅,启动操作")
observer.send(value: "Hello")
observer.send(value: "World")
} let subscriber1 = Observer<String, NoError>(value: { print("观察者1接收到值 \($0)") })
let subscriber2 = Observer<String, NoError>(value: { print("观察者2接收到值 \($0)") }) print("观察者1订阅信号发生器")
producer.start(subscriber1)
print("观察者2订阅信号发生器")
producer.start(subscriber2)
//注意:发生器将再次启动工作 // 2.通过管道创建(热信号)
let (signalA, observerA) = Signal<String, NoError>.pipe()
let (signalB, observerB) = Signal<String, NoError>.pipe()
Signal.combineLatest(signalA, signalB).observeValues { (value) in
print( "收到的值\(value.0) + \(value.1)")
}
observerA.send(value: "")
//注意:如果加这个就是,发了一次信号就不能再发了
observerA.sendCompleted()
observerB.send(value: "")
observerB.sendCompleted() //3.创建空信号
let emptySignal = Signal<Any, NoError>.empty
emptySignal.observe { (value) in }
2.基本控件用法
//MARK:通知
private func noti() { NotificationCenter.default.reactive.notifications(forName: Notification.Name(rawValue: "UIKeyboardWillShowNotification"), object: nil).observeValues { (value) in } NotificationCenter.default.post(name: Notification.Name(rawValue: "name"), object: self)
} //MARK:KVO
private func kvoWithRac() { view.reactive.values(forKeyPath: "bounds").start { [weak self](rect) in
print(self?.view ?? "")
print(rect)
}
} //MARK:按钮点击
private func btnWithRAC() { //1.点击
btn.tag =
btn.isEnabled = true
btn.reactive.controlEvents(.touchUpInside).observeValues { (btn) in
print("点击了按钮,颜色\(btn.tag)")
}
} //textField
textField.reactive.continuousTextValues.observeValues { (value) in }
3.过滤 filter
//filter作用:过滤 当text>5才会输出
textField.reactive.continuousTextValues.filter { (text) -> Bool in return (text?.characters.count)! >
}.observe({
text in
print(text)
})
4.转换 map
//每一次map接收到的Value事件,它就会运行closure,以closure的返回值作为Value事件发送出去。上面的代码中,我们的text的值映射成text的字符数
textField.reactive.continuousTextValues.map { (text) -> Int in
return (text?.characters.count)!
}.filter { (length) -> Bool in
return length >
}.observe { (length) in
print(length)
} //(改变属性)使用map与observeValues结合改变属性
textField.reactive.continuousTextValues
.map { (text) -> Int in
return (text?.characters.count)!
}
.map { (length) -> UIColor in
return length > ? UIColor.red : UIColor.yellow
}
.observeValues { (backgroundColor) in
self.textField.backgroundColor = backgroundColor
}
5.两个信号结合使用 <~
//1.
let nameSign = textField.reactive.continuousTextValues.map { (text) -> Int in
return (text?.characters.count)!
}
let passSign = passwordtextField.reactive.continuousTextValues.map { (text) -> Int in
return (text?.characters.count)!
}
btn.reactive.isEnabled <~ Signal.combineLatest(nameSign, passSign).map({(namelength : Int, passlength : Int) -> Bool in return namelength >= && passlength >
})
//2.
Signal.combineLatest(nameSign,passSign).observeValues { (namelength : Int, passlength : Int) in
}
6.Scheduler(调度器)延时加载
// 主线程上延时0.3秒调用
QueueScheduler.main.schedule(after: Date.init(timeIntervalSinceNow: 0.3)) {
print("主线程调用")
} QueueScheduler.init().schedule(after: Date.init(timeIntervalSinceNow: 0.3)){
print("子线程调用")
}
7.迭代器
// 数组的迭代器
let array:[String] = ["name","name2"]
var arrayIterator = array.makeIterator()
while let temp = arrayIterator.next() {
print(temp)
} // swift 系统自带的遍历
array.forEach { (value) in
print(value)
} // 字典的迭代器
let dict:[String: String] = ["key":"name", "key1":"name1"]
var dictIterator = dict.makeIterator()
while let temp = dictIterator.next() {
print(temp)
} // swift 系统自带的遍历
dict.forEach { (key, value) in
print("\(key) + \(value)")
}
8.信号联合
func testZip() {
let (signalA, observerA) = Signal<Any, NoError>.pipe()
let (signalB, observerB) = Signal<String, NoError>.pipe()
Signal.zip(signalA, signalB).observeValues { (value) in
print(value)
}
signalA.zip(with: signalB).observeValues { (value) in
}
observerA.send(value: "")
observerA.sendCompleted()
observerB.send(value: "")
observerB.sendCompleted()
}
9.代替delegate
.
import ReactiveCocoa
import ReactiveSwift
import Result .let (signalTap , observerTap) = Signal<Any, NoError>.pipe()
observerTap.send(value: tap)
自定义个view
class LyContentView: UIView { let (signalTap , observerTap) = Signal<Any, NoError>.pipe() override init(frame: CGRect) {
super.init(frame: frame) setUI()
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
} } extension LyContentView {
fileprivate func setUI() {
backgroundColor = UIColor.yellow let tap = UITapGestureRecognizer(target: self, action: #selector(self.tapClick(_:)))
addGestureRecognizer(tap)
} //使用RAC,替代delegate,闭包
@objc fileprivate func tapClick(_ tap : UITapGestureRecognizer) {
observerTap.send(value: tap)
}
}
.控制器中监听
contentView.signalTap.observeValues { (value) in
print("点击了view")
}
Demo:https://github.com/zhangjie579/LyReactiveSwiftDemo
RAC,ReactiveSwift的更多相关文章
- ReactiveSwift框架
最近项目不多,所以就研究了一下RxSwift和RAS,RAC以前项目中用过了,在这里我就先简单的介绍一下什么是RAS.总述:在RAC 5.0这个版本,有了很大的改动,API已经重新命名.在和Swift ...
- ReactiveSwift日常运用<一>
上一篇中,我已经很详细的介绍了ReactiveSwift,接下来我就举几个简单的例子供大家参考.1.键盘的监听这在我们开发中很常用,因为很多App都需要对登录注册进行判断,这样可以避免服务器存储很多废 ...
- ReactiveObjC(RAC)的使用汇总
RAC 指的就是 RactiveCocoa ,是 Github 的一个开源框架,能够帮我们提供大量方便的事件处理方案,让我们更简单粗暴地去处理事件,现在分为 ReactiveObjC 和 Reacti ...
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 1.实施前准备工作 1.1 服务器安装操 ...
- 利用XAG在RAC环境下实现GoldenGate自动Failover
概述 在RAC环境下配置OGG,要想实现RAC节点故障时,OGG能自动的failover到正常节点,要保证两点: 1. OGG的checkpoint,trail,BR文件放置在共享的集群文件系统上,R ...
- 【Oracle 集群】ORACLE DATABASE 11G RAC 知识图文详细教程之集群概念介绍(一)
集群概念介绍(一)) 白宁超 2015年7月16日 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习 ...
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 3.安装Clus ...
- 使用SwingBench 对Oracle RAC DB性能 压力测试
我们可以使用swingbench这个工具对数据库性能进行压力测试,得到一些性能指标作为参考. SwingBench下载: http://www.dominicgiles.com/downloads.h ...
随机推荐
- windows下java项目打包、启动批处理 .bat文件
maven打包,脚本内容: @echo off echo 正在设置临时环境变量 set JAVA_HOME=C:\Program Files\Java\jdk1.6.0_45 set MAVEN_HO ...
- java核心-多线程-零碎知识收集
1.不能使用Integer作为并发锁 原因:synchronized(Integer)时,当值发生改变时,基本上每次锁住的都是不同的对象实例,想要保证线程安全,推荐使用AtomicInteger之类会 ...
- 二十、SAP中定义内表
一.内表相当于传统语言的多维数组的东西,定义一个内表有以下2个方式
- 201912-1 报数 Java
思路: String.valueOf(int i) : 将 int 变量 i 转换成字符串 String.contains()用于判断字符串是否包含子字符串 import java.util.Scan ...
- P 1025 链表反转
转跳点:
- UVA - 12113 Overlapping Squares(重叠的正方形)
题意:给定一个4*4的棋盘和棋盘上所呈现出来的纸张边缘,问用不超过6张2*2的纸能否摆出指定的形状. 分析:2*2的纸在4*4的棋盘上总共有9种放置位置,枚举所有的放置位置即可.枚举情况总共种. #p ...
- 覆盖.project
<?xml version="1.0" encoding="UTF-8"?> <projectDescription> <name ...
- mybatis环境搭建(eclipse,idea)
基于java配置SSM,eclipse 新建maven,web项目 .... 项目结构: jar包 pom.xml spring和DispatcherServlet上下文 public class D ...
- python的常用序列
list1.list(obj)函数 obj可以为:元组(1,2,3),可迭代对象,字符串等转换换成数组类型2. 列表元素的添加 (1)list+[添加的元素] (2)list.append(添加元素) ...
- 吴裕雄--天生自然TensorFlow2教程:张量排序
import tensorflow as tf a = tf.random.shuffle(tf.range(5)) a tf.sort(a, direction='DESCENDING') # 返回 ...