iOS 监听回调机制KVO
2018-01-17 15:42
204 查看
监听某个对象,如果这个对象的数据发生变化,会发送给监听者从而触发回调函数
[self.bean addObserver:self forKeyPath:@"data" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
这个就是注册监听,这个@“data”作为标识符方便回调函数辨认
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if([keyPath isEqualToString:@"data"])
{
self.label.text = [self.bean valueForKey:@"data"];
}
}
这个就是回调函数,分辨是哪个对象发生变化,然后给与相应的处理
-(void)viewWillDisappear:(BOOL)animated{
[self.bean removeObserver:self forKeyPath:@"data"];
}
既然有注册监听还记得解除监听
以下是完整例子代码
//
// ViewController.m
// First
//
// Created by shanreal-iOS on 17/10/16.
// Copyright © 2017年 shanreal.LongZhenHao. All rights reserved.
//
#import "ViewController.h"
#import "TestBean.h"
@interface ViewController ()
@property(nonatomic,strong)UILabel* label;
@property(nonatomic,strong)UIButton* btn;
@property(nonatomic,strong)TestBean* bean;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
self.bean = [[TestBean alloc]init];
[self.bean setValue:@"1" forKey:@"data"];
self.label = [[UILabel alloc]initWithFrame:CGRectMake(10, 30, 100, 30)];
self.label.textColor = [UIColor blackColor];
self.label.text = [self.bean valueForKey:@"data"];
[self.view addSubview:self.label];
self.btn = [[UIButton alloc] initWithFrame:CGRectMake(10, 100, 200, 30)];
[self.btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[self.btn setTitle:@"chanage data" forState:UIControlStateNormal];
[self.btn addTarget:self action:@selector(clickAction) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:self.btn];
}
-(void)viewWillAppear:(BOOL)animated{
[self.bean addObserver:self forKeyPath:@"data" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
}
-(void)clickAction{
int data = [[self.bean valueForKey:@"data"] intValue]+1;
self.bean.data = [NSString stringWithFormat:@"%d",data];
}
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if([keyPath isEqualToString:@"data"])
{
self.label.text = [self.bean valueForKey:@"data"];
}
}
-(void)viewWillDisappear:(BOOL)animated{
[self.bean removeObserver:self forKeyPath:@"data"];
}
@end
#import <Foundation/Foundation.h>
@interface TestBean : NSObject{
NSString* data;
}
@property(nonatomic,assign)int id;
@property(nonatomic,strong)NSString* data;
@end
#import "TestBean.h"
@implementation TestBean
@end
[self.bean addObserver:self forKeyPath:@"data" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
这个就是注册监听,这个@“data”作为标识符方便回调函数辨认
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if([keyPath isEqualToString:@"data"])
{
self.label.text = [self.bean valueForKey:@"data"];
}
}
这个就是回调函数,分辨是哪个对象发生变化,然后给与相应的处理
-(void)viewWillDisappear:(BOOL)animated{
[self.bean removeObserver:self forKeyPath:@"data"];
}
既然有注册监听还记得解除监听
以下是完整例子代码
//
// ViewController.m
// First
//
// Created by shanreal-iOS on 17/10/16.
// Copyright © 2017年 shanreal.LongZhenHao. All rights reserved.
//
#import "ViewController.h"
#import "TestBean.h"
@interface ViewController ()
@property(nonatomic,strong)UILabel* label;
@property(nonatomic,strong)UIButton* btn;
@property(nonatomic,strong)TestBean* bean;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
self.bean = [[TestBean alloc]init];
[self.bean setValue:@"1" forKey:@"data"];
self.label = [[UILabel alloc]initWithFrame:CGRectMake(10, 30, 100, 30)];
self.label.textColor = [UIColor blackColor];
self.label.text = [self.bean valueForKey:@"data"];
[self.view addSubview:self.label];
self.btn = [[UIButton alloc] initWithFrame:CGRectMake(10, 100, 200, 30)];
[self.btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[self.btn setTitle:@"chanage data" forState:UIControlStateNormal];
[self.btn addTarget:self action:@selector(clickAction) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:self.btn];
}
-(void)viewWillAppear:(BOOL)animated{
[self.bean addObserver:self forKeyPath:@"data" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
}
-(void)clickAction{
int data = [[self.bean valueForKey:@"data"] intValue]+1;
self.bean.data = [NSString stringWithFormat:@"%d",data];
}
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if([keyPath isEqualToString:@"data"])
{
self.label.text = [self.bean valueForKey:@"data"];
}
}
-(void)viewWillDisappear:(BOOL)animated{
[self.bean removeObserver:self forKeyPath:@"data"];
}
@end
#import <Foundation/Foundation.h>
@interface TestBean : NSObject{
NSString* data;
}
@property(nonatomic,assign)int id;
@property(nonatomic,strong)NSString* data;
@end
#import "TestBean.h"
@implementation TestBean
@end
相关文章推荐
- iOS 监听回调机制KVO实例
- 回调机制在 Android 监听用户界面操作中的体现
- iOS中消息传递机制(KVO,Notification,delegation,block,Target-Action)
- IOS 的 KVO机制
- iOS拦截系统KVO监听,防止多次删除和添加
- iOS监听模式系列之键值编码KVC、键值监听KVO的简单介绍和应用
- android事件监听回调机制
- 【iOS】KVO方式监听数组的变化动态刷新tableView
- 回调机制在 Android 监听用户界面操作中的体现
- 【IOS 开发学习总结-OC-14】★★★objective-c面向对象之——KVO(键值监听)
- iOS监听模式系列之键值编码KVC、键值监听KVO的简单介绍和应用
- IOS的KVO不能监听的场景
- iOS学习——KVO底层实现机制探究
- iOS开发之旅--KVO监听对象底层原理
- 回调函数在Android监听机制中的体现
- 自定义组件 回调、监听机制下的优先级
- iOS监听模式之KVO、KVC的高阶应用
- 通过View的OnClickListener监听机制的模型,来解析回调机制
- 和我一起来学iOS(二)iOS中的一些约定、模式与三种回调机制
- UIAlertController 自定义输入框及KVO监听 分类: ios技术 2015-01-20 15:33 199人阅读 评论(1) 收藏