OC-KVO

在OC中有个非常强大的功能,KVC KVC的作用是通过键值对找到值,或者设置值

KVO 是基于KVC 的功能



-第一步

注册成为观察者

-addObserver:forKeyPath:option:context方法代码如下:

<pre name="code" class="objc"><span style="font-size:18px;"><span style="white-space:pre">	</span>    [111 addObserver:222 forKeyPath:333 options:444 context:555];</span>

 

其中 参数111  表示接受通知的对象,即为观察者 ,常为self

参数222  表示键路径参数,就是要观察的键路径     例如 label的text  view的background

参数333 表示KVO变化将这些值传给观察者  可以通过 | 来多选,传入的值如下

NSKeyValueObservingOptionNew 把更改之后的值提供给观察者的回调方法

NSKeyValueObservingOptionOld 把更改之前的值提供给观察者的回调方法

NSKeyValueObservingOptionInitial 把初始化的值提供给观察者的回调方法,一旦注册,立马就会调用一 次,通常它会带有新值,而不会带有旧值

NSKeyValueObservingOptionPrior  在变更前后分别发送变更,而不只在变更后发送回一次,分2次调用, 在值改变之前和值改变之后

参数444 表示上下文内存区,通常为nil

第二步编写观察者的回调方法

-(void)observeValueForKeyPath:(NSString *)keyPath  //参数1

ofObject:(id)object //参数2

 change:(NSDictionary<NSString *,id> *) //参数3

change context:(void *)context //参数4

{ }

方法的参数与注册时候的参数是一样的

其中参数3是传回一个字典 可以通过 [change objectForkey ]来获取里面的值

第3步移除观察者

-(void)dealloc{

[self.XXX removeObserver:self forKeyPath:"111"]; //111表示键值对

}




下面是一个KVO的小示例

功能实现是,滑动 Slider   键"vlaue"就会发生改变,然后通过观察者的回调方法,相应事件 改变 self.view.alpha(透明度)

下面是代码:

//
//  ViewController.m
//  KVO
//
//  Created by Ibokan on 15/12/22.
//  Copyright © 2015年 Ibokan. All rights reserved.
//

#import "ViewController.h"
@interface ViewController ()
@property (weak, nonatomic) IBOutlet UISlider *mySlider;

@end

@implementation ViewController

- (void)viewDidLoad {
    [self.mySlider addObserver:self forKeyPath:@"value" options:NSKeyValueObservingOptionNew context:nil];
     [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context{
    self.view.alpha=self.mySlider.value;
}
-(void)dealloc{
[self.mySlider<span style="white-space:pre">	</span>removeObserver:self forKeyPath:@"value"];

}
@end


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值