ReactiveCocoa框架学习<一>
1.Cocoapods导入ReactiveCocoa:
use_frameworks!
target 'RACDemo' do
pod 'ReactiveObjC', '~> 2.1.0' end
不懂得可以看这个链接: http://www.tuicool.com/articles/Qju6fme
2.输出文本内容操作:
//
// ViewController.m
// RACDemo
//
// Created by 思 彭 on 17/1/4.
// Copyright © 2017年 思 彭. All rights reserved.
// #import "ViewController.h"
#import <ReactiveObjC/ReactiveObjC.h> @interface ViewController ()
@property (weak, nonatomic) IBOutlet UILabel *userNameLabel;
@property (weak, nonatomic) IBOutlet UILabel *passwordLabel;
@property (weak, nonatomic) IBOutlet UITextField *userNameTF;
@property (weak, nonatomic) IBOutlet UITextField *passwordTF; @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; // 1.每次改变文本框中的文字,block中的代码都会执行。没有target-action,没有delegate,只有signal和block
[self.userNameTF.rac_textSignal subscribeNext:^(NSString * _Nullable x) { NSLog(@"text = %@",x);
}]; // 2.只关心超过3个字符长度的用户名
[[self.userNameTF.rac_textSignal filter:^BOOL(NSString * _Nullable value) {
NSString *text = value;
return text.length > ;
}]
subscribeNext:^(NSString * _Nullable x) {
NSLog(@"---%@",x);
}]; // 3.上面步骤分解如下:
RACSignal *userNameSourceSignal = self.userNameTF.rac_textSignal;
RACSignal *filteredUsername = [userNameSourceSignal filter:^BOOL(id _Nullable value) { NSString *text = value;
return text.length > ;
}];
[filteredUsername subscribeNext:^(id _Nullable x) {
NSLog(@"---%@",x);
}];
} @end
3.输出文本长度操作:
// 1.输出文本长度 > 的长度:
// map操作之后的步骤收到的都是NSNumber实例。你可以使用map操作来把接收的数据转换成想要的类型,只要它是个对象。
[[[self.userNameTF.rac_textSignal map:^id _Nullable(NSString * _Nullable value) {
return @(value.length);
}] filter:^BOOL(id _Nullable value) {
return [value integerValue] > 3;
}] subscribeNext:^(id _Nullable x) {
NSLog(@"length = %@",x);
}];
4.创建一些信号,来表示用户名和密码输入框中的输入内容是否有效,设置背景颜色:
// 2.创建一些信号,来表示用户名和密码输入框中的输入内容是否有效
RACSignal *validUserNameSignal = [self.userNameTF.rac_textSignal map:^id _Nullable(NSString * _Nullable value) { return @([self isValidUsername:value]); // 输出是一个用NSNumber封装的布尔值
}]; RACSignal *validPasseordSifnal = [self.passwordTF.rac_textSignal map:^id _Nullable(NSString * _Nullable value) { return @([self isValidPassword:value]);
}]; // 3.转换这些信号,从而能为输入框设置不同的背景颜色
[[validUserNameSignal map:^id _Nullable(id _Nullable value) { return [value boolValue] ? [UIColor clearColor] : [UIColor yellowColor];
}] subscribeNext:^(id _Nullable x) {
self.passwordTF.backgroundColor = x;
}]; [[validPasseordSifnal map:^id _Nullable(id _Nullable value) { return [value boolValue] ? [UIColor clearColor] : [UIColor yellowColor];
}] subscribeNext:^(id _Nullable x) {
self.passwordTF.backgroundColor = x;
}]; // 4.宏来更好的完成上面的事情
RAC(self.passwordTF, backgroundColor) = [validPasseordSifnal map:^id _Nullable(id _Nullable value) { return [value boolValue] ? [UIColor clearColor] : [UIColor yellowColor];
}]; RAC(self.userNameTF, backgroundColor) = [validUserNameSignal map:^id _Nullable(id _Nullable value) {
return [value boolValue] ? [UIColor clearColor] : [UIColor yellowColor];
}];
} - (BOOL)isValidUsername:(NSString *)username {
return username.length > ;
} - (BOOL)isValidPassword:(NSString *)password {
return password.length > ;
}
5.登录按钮的点击进入判断条件:
// 5.聚合信号 登录按钮只有当用户名和密码输入框的输入都有效时才工作
RACSignal *signUpActiveSignal = [RACSignal combineLatest:@[validUserNameSignal ,validPasseordSifnal] reduce:^id (NSNumber *userNameValid, NSNumber *passwordValid) { return @([userNameValid boolValue] && [passwordValid boolValue]);
}];
[signUpActiveSignal subscribeNext:^(id _Nullable x) { self.logInButton.enabled = [x boolValue];
}];
6.登录按钮触发:
[[self.logInButton rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(__kindof UIControl * _Nullable x) {
NSLog(@"button Click---");
}];
[[[self.logInButton
rac_signalForControlEvents:UIControlEventTouchUpInside]
flattenMap:^id(id x){
return[self logginSignal];
}]
subscribeNext:^(NSNumber*signedIn){
BOOL success =[signedIn boolValue];
if(success){
NSLog(@"成功登录");
ViewController1 *vc1 = [[ViewController1 alloc]init];
[self.navigationController pushViewController:vc1 animated:YES];
}
}];
学了一些基础,慢慢学习吧!!! 需要源码的可以Q我哟!! 1299625033..哈哈
参考博文链接: http://www.cocoachina.com/ios/20150123/10994.html
ReactiveCocoa框架学习<一>的更多相关文章
- ReactiveCocoa框架学习1
写block直接使用inline block的声明类型 在ARC中使用strong,如果不使用strong,则会被销毁 在非ARC中使用copy block在开发中的使用场景 把block保存到对象中 ...
- ReactiveCocoa框架学习2
昨天内容回顾 信号类:表示有数据产生,信号类不发送数据 注意:不同的信号,订阅方式不同 RACSignal 创建RACDynamicSignal信号 -> didSubscribe(block) ...
- ReactiveCocoa 入门学习 (一)
引言 现在由于需求的不断发展,MVC这个经典的框架由于Controller的任务越来越多,显得"臃肿"了,网上又推出了新的框架,比如MVVM,ReactiveCocoa, 今天就来 ...
- IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习保护API
IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习之保护API. 使用IdentityServer4 来实现使用客户端凭据保护ASP.N ...
- Hadoop学习笔记—18.Sqoop框架学习
一.Sqoop基础:连接关系型数据库与Hadoop的桥梁 1.1 Sqoop的基本概念 Hadoop正成为企业用于大数据分析的最热门选择,但想将你的数据移植过去并不容易.Apache Sqoop正在加 ...
- Spring框架学习一
Spring框架学习,转自http://blog.csdn.net/lishuangzhe7047/article/details/20740209 Spring框架学习(一) 1.什么是Spring ...
- EF框架学习手记
转载: [ASP.NET MVC]: - EF框架学习手记 1.EF(Entity Framework)实体框架EF是ADO.NET中的一组支持开发面向数据的软件应用程序的技术,是微软的一个ORM框架 ...
- web框架学习列表
转载自鲁塔弗的博客,原文网址:http://lutaf.com/148.htm web framework层出不穷,特别是ruby/python,各有10+个,php/java也是一大堆 根据我自己的 ...
- 2013 最新的 play web framework 版本 1.2.3 框架学习文档整理
Play framework框架学习文档 Play framework框架学习文档 1 一.什么是Playframework 3 二.playframework框架的优点 4 三.Play Frame ...
随机推荐
- appium移动端测试之滑动(二)
在ios测试中,需要用到滑动,所以用java封装了一套滑动的方法,不多说,贴代码 /** * 上滑1/4屏幕 */ public void slideUP1_4() { int x = driver. ...
- 【原创】loadrunner12.53 录制脚本时 打不开网页或者打开网页慢?
问题描述: 之前刚装12.5版本时候,用 WebTours测试过,应用程序选择自己本地IE浏览器.exe程序,输入url地址就可以成功录制了 . 但是由于公司网络配置环境改变了(猜测),现 ...
- Redis安装手册
转载请注明出处:http://www.cnblogs.com/robinjava77/p/5465146.html (Robin) 1)下载redis:wget http://download.red ...
- 【SSM 6】Spring+SpringMVC+Mybatis框架搭建步骤
一.整体概览 首先看maven工程的创建 二.各层的文件配置 2.1,SSM父工程 <span style="font-family:KaiTi_GB2312;font-size:18 ...
- 2016/9/25编写java实验报告时对synchronized(同步代码块)的一些感悟
通过此次实验,明白了多线程的设置和启动.synchronized代码块的用法.线程的优先级使用方法.知道了那几类资源是线程共享的. 我现在理解的多线程是:实例化一个继承了Thread类或实现了Runn ...
- iOS开发阶段技能总结
这是一篇自己平时纪录的笔记... 1.基本的数据结构常识:链表,队列,栈 2.基本的算法:排序,动态规划等常用算法 3.基本的概念,cocoa,各种自带的view的使用. 4.xcode自带的测试:O ...
- Openstack Basic
html,body { } .CodeMirror { height: auto } .CodeMirror-scroll { } .CodeMirror-lines { padding: 4px 0 ...
- bootstrapValidator.js,最好用的bootstrap表单验证插件
前言:做Web开发的我们,表单验证是再常见不过的需求了.友好的错误提示能增加用户体验.博主搜索bootstrap表单验证,搜到的结果大部分都是文中的主题:bootstrapvalidator.今天就来 ...
- subline text3 删除行 快捷键设置
打开 首选项-->按键绑定 { "keys": ["ctrl+shift+k"], "command": "run_macr ...
- 100怎么变成100.00 || undefined在数字环境下是:NaN || null在数字环境下是0 || 数组的toString()方法把每个元素变成字符串,拼在一起以逗号隔开 || 空数组转换成字符串后是什么?
100怎么变成100.00?