iOS 監(jiān)聽(tīng)回調(diào)機(jī)制KVO實(shí)例
監(jiān)聽(tīng)某個(gè)對(duì)象,如果這個(gè)對(duì)象的數(shù)據(jù)發(fā)生變化,會(huì)發(fā)送給監(jiān)聽(tīng)者從而觸發(fā)回調(diào)函數(shù)
[self.bean addObserver:self forKeyPath:@"data" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
這個(gè)就是注冊(cè)監(jiān)聽(tīng),這個(gè)@“data”作為標(biāo)識(shí)符方便回調(diào)函數(shù)辨認(rèn)
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context { if([keyPath isEqualToString:@"data"]) { self.label.text = [self.bean valueForKey:@"data"]; } }
這個(gè)就是回調(diào)函數(shù),分辨是哪個(gè)對(duì)象發(fā)生變化,然后給與相應(yīng)的處理
-(void)viewWillDisappear:(BOOL)animated{ [self.bean removeObserver:self forKeyPath:@"data"]; }
既然有注冊(cè)監(jiān)聽(tīng)還記得解除監(jiān)聽(tīng)
以下是完整例子代碼
// // 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 監(jiān)聽(tīng)回調(diào)機(jī)制KVO實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
IOS使用NSUserDefault去實(shí)現(xiàn)界面?zhèn)髦岛蛿?shù)據(jù)存儲(chǔ)
這篇文章主要介紹了IOS使用NSUserDefault去實(shí)現(xiàn)界面?zhèn)髦岛蛿?shù)據(jù)存儲(chǔ)的相關(guān)資料,需要的朋友可以參考下2017-07-07iOS tableView實(shí)現(xiàn)下拉圖片放大效果
這篇文章主要為大家詳細(xì)介紹了iOS tableView實(shí)現(xiàn)下拉圖片放大效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05將多個(gè)字符串高亮顯示之TTTAttributedLabel
本文介紹了將多個(gè)字符串高亮顯示之TTTAttributedLabel。在此需要對(duì)每個(gè)字符串進(jìn)行匹配,可以研究下kmp和bm算法,在這里應(yīng)用了oc自帶的NSRegularExpression 來(lái)進(jìn)行正則表達(dá)式匹配,算是比較簡(jiǎn)單的方法,需要的朋友可以參考下2015-07-07iOS中tableView cell分割線的一些設(shè)置技巧
在項(xiàng)目開(kāi)發(fā)中我們會(huì)常常遇到tableView 的cell分割線顯示不全,左邊會(huì)空出一截像素,更有甚者想改變系統(tǒng)的分割線,下面通過(guò)這篇文章來(lái)一起學(xué)習(xí)學(xué)習(xí)在iOS中tableView cell分割線的一些設(shè)置技巧,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-05-05IOS中實(shí)現(xiàn)圖片點(diǎn)擊全屏預(yù)覽
IOS作為一款智能手機(jī)系統(tǒng),在查看圖片的時(shí)候,如果能夠?qū)崿F(xiàn)全屏,對(duì)用戶來(lái)說(shuō)有很好的視覺(jué)體驗(yàn),其實(shí)實(shí)現(xiàn)起來(lái)非常的簡(jiǎn)單,下面我就結(jié)合一個(gè)簡(jiǎn)單的代碼給大家來(lái)分享一下,,需要的朋友可以參考下2015-11-11