界面之间的数据正逆向/多层次传递方法

1 初始化传值

(重写init方法,让后面携带需要传入的数据,然后在对界面初始化,使用这种方法必须要在初始化前就已经有数据了比较适合)

[objc] view plain copy

#import   


@interface CustomView : UIView  

// 需要注意必须在 (.h)对方法进行声明 在外部创建这个类的时候才能看到  

- (instancetype)initWithFrame:(CGRect)frame withInformation:(NSDictionary *)dict;  

@end  

[objc] view plain copy

#import "CustomView.h"  


@implementation CustomView  


- (instancetype)initWithFrame:(CGRect)frame withInformation:(NSDictionary *)dict  

{  

self = [super initWithFrame:frame];  

if (self) {  

// 进行页面配置,直接可以拿到自己想要的数据通过字典  

    }  

return self;  

}  


@end  

[objc] view plain copy

- (void)initUserInterface  

{  

NSDictionary *dict = [NSDictionary dictionary];  

// 调用init自定义方法 传入数据  

CustomView *customView = [[CustomView alloc]initWithFrame:self.view.bounds withInformation:dict];  

[self.view addSubview:customView];  

}  

2 属性传值

 (属性传值比较合适界面是先初始化的,而数据在界面初始化之后才拿到的,当想要对界面的元素的内容进行更新,直接通过属性拿到对应的元素进行更改比较方便。特别是做数据请求用tableView来展示的时候,请求数据和页面创建同步进行,所以用init传请求数据必然会是空,那么就需要在数据请求成功用,在把界面元素就行刷新,而cell也是自定义的,最好把需要更新的控件定义成属性就好对数据进行刷新处理了)

[objc] view plain copy

#import   



@interface CustomView : UIView  


@property (nonatomic,retain)UILabel *label;  


@end  

[objc] view plain copy

#import "CustomView.h"  


@implementation CustomView  


- (instancetype)initWithFrame:(CGRect)frame  

{  

self = [super initWithFrame:frame];  

if (self) {  


_label = [[UILabel alloc]init];  

_label.text = @"属性传值";  

[self addSubview:_label];  


    }  

return self;  

}  


@end  

[objc] view plain copy

#import "ViewController.h"  

#import "CustomView.h"  


@interface ViewController ()  


@end  


@implementation ViewController  


- (void)viewDidLoad {  

[super viewDidLoad];  


[self initUserInterface];  

}  


- (void)initUserInterface  

{  

CustomView *customView = [[CustomView alloc]initWithFrame:self.view.bounds];  

// 拿到它的属性 进行我们需要的操作  

customView.label.text = @"修改显示数据";  

[self.view addSubview:customView];  

}  


@end  

3 方法参数传值

 (方法参数传值也很适合对界面元素更新使用,当想要让封装好的一个TableView刷新请求回来数据时,通过调用封装的这个方法传入数据就可以刷新界面数据)

4 协议传值

(比较适合两个界面直接的逆向传值__>也是类似实现系统的代理方法,当某个封装好的类,定义一个自己的代理,当这个类里触发的某个事件需要把数据传出去,就在协议里定义一个方法,当遵守这个协议的实例调用这个方法就可以访问后面携带的参数)

以下是简单封装的一个view来做例子说明  分别是封装的.h  .m  文件

[objc] view plain copy

#import   


@protocol CustomViewDelegate   

// delegate 必须实现的方法  

@required  

- (void)sendInformation:(NSInteger)tag;  

// delegate 选择实现的方法  

@optional  


@end  


@interface CustomView : UIView  


@property (nonatomic,assign)id  delegate;  


@end  

[objc] view plain copy

#import "CustomView.h"  


@implementation CustomView  


- (instancetype)initWithFrame:(CGRect)frame  

{  

self = [super initWithFrame:frame];  

if (self) {  


UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];  

button.tag = 111;  

[button addTarget:self action:@selector(buttonPressed:) forControlEvents:UIControlEventTouchUpInside];  

[self addSubview:button];  

    }  

return self;  

}  


- (void)buttonPressed:(UIButton *)sender  

{  

[self.delegate sendInformation:sender.tag];  

}  

@end  

主页面显示VC

[objc] view plain copy

#import "ViewController.h"  

#import "CustomView.h"  


@interface ViewController ()  


@end  


@implementation ViewController  


- (void)viewDidLoad {  

[super viewDidLoad];  


[self initUserInterface];  

}  


- (void)initUserInterface  

{  

CustomView *customView = [[CustomView alloc]initWithFrame:self.view.bounds];  

// 创建实例给他代理  

customView.delegate = self;  

[self.view addSubview:customView];  

}  


#pragma mark - CustomViewDelegate  

- (void)sendInformation:(NSInteger)tag  

{  

// 当触发button事件的时候,就会调用这个方法,把数据传过来,类比于tableView 点击的了对应的行就会走代理的方法  

NSLog(@"%ld",tag);  

}  


- (void)didReceiveMemoryWarning {  

[super didReceiveMemoryWarning];  

// Dispose of any resources that can be recreated.  

}  


@end  

5 Block传值


6 单例传值

 (使用单例一般比较时候存储用户信息之类的,方便数据访问或其他时候数据随时调用)

7 通知传值

 (当需要夸多层次的页面进行数据传送的时候,注册通知来实现是比较方便的,而且使用起来也是非常简单)

[objc] view plain copy

#import "ViewController.h"  

#import "CustomView.h"  


@interface ViewController ()  


- (void)getInformation:(NSNotification *)noti;  


@end  


@implementation ViewController  


- (void)viewDidLoad {  

[super viewDidLoad];  


[self initUserInterface];  

}  


- (void)initUserInterface  

{  

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(getInformation:) name:@"sendData" object:nil];  

}  


#pragma mark - NSNotificationCenter methods  

// 发送通知后,就会走这个方法  

- (void)getInformation:(NSNotification *)noti  

{  


/****************   Notifications   ****************/  

/*

    @interface NSNotification : NSObject 


    @property (readonly, copy) NSString *name;

    @property (readonly, retain) id object;

    @property (readonly, copy) NSDictionary *userInfo;


    */  

// 把传过来的数据进行打印  


NSLog(@"%@",noti.object); // 直接用点属性获取传送过来的数据即可  


}  


@end  

[objc] view plain copy

#import "CustomView.h"  


@implementation CustomView  


- (instancetype)initWithFrame:(CGRect)frame  

{  

self = [super initWithFrame:frame];  

if (self) {  


UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];  

[button addTarget:self action:@selector(postNoti) forControlEvents:UIControlEventTouchUpInside];  

[self addSubview:button];  


    }  

return self;  

}  

// 点击了button 发送通知  

- (void)postNoti  

{  

NSString *string = @"send any data";  

[[NSNotificationCenter defaultCenter] postNotificationName:@"sendData"  

 object:string];// object 为ID 可以传送任意类型数据 这里传得时字符串  

}  


@end  

8 extern全局变量

9 数据存储

(数据持久化 写入沙盒) 

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容