UI總結(jié)-界面?zhèn)髦?/h1>

UI總結(jié)-界面?zhèn)髦?屬性傳值,協(xié)議傳值,block傳值,通知中指傳值)

在編程過程中,界面?zhèn)髦凳呛苤匾囊徊糠?常用的傳值方式就有四種:屬性傳值,協(xié)議傳值,block傳值,通知中指傳值,下面通過簡單的代碼來實(shí)現(xiàn)這四種傳值方式:

前一個(gè)界面ViewController.m文件:

#import "ViewController.h"

#import "SecondViewController.h"

//4.簽訂協(xié)議

@interface ViewController ()

@property(nonatomic, retain)UITextField *text;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

self.view.backgroundColor = [UIColor whiteColor];

UIButton *btn = [UIButton buttonWithType:UIButtonTypeSystem];

btn.backgroundColor = [UIColor redColor];

[self.view addSubview:btn];

btn.frame = CGRectMake(100, 100, 200, 50);

btn.layer.borderWidth = 1;

btn.layer.cornerRadius = 5;

[btn setTitle:@"下一頁" forState:UIControlStateNormal];

[btn addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];

self.text = [[UITextField alloc]initWithFrame:CGRectMake(100, 200, 200, 50)];

self.text.backgroundColor = [UIColor blueColor];

[self.view addSubview:self.text];

[_text release];

self.text.layer.borderWidth = 1;

self.text.layer.cornerRadius = 5;

//第四種傳值方式:通知中心

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

}

-(void)click:(UIButton *)button{

SecondViewController *vc = [[SecondViewController alloc]init];

[self.navigationController pushViewController:vc animated:YES];

//屬性傳值

//在要傳值的后一個(gè)頁面定義屬性,在對應(yīng)的視圖控制器調(diào)用屬性進(jìn)行賦值,就可以將值傳到后一個(gè)頁面

vc.str = self.text.text;

vc.arr = @[@"james", @"alice", @"tom"];

//5.設(shè)置代理人

vc.delegate = self;

//先寫一個(gè)block

void(^block)() = ^(){

self.view.backgroundColor = [UIColor blueColor];

};

//傳值

vc.block = block;

[vc release];

}

//6.實(shí)現(xiàn)代理方法

-(void)sendValue:(NSString *)str{

self.title = str;

}

-(void)jieshou:(NSNotification *)notification{

self.text.text = [notification.userInfo valueForKey:@"name"];

}

后一個(gè)界面SecondViewController.h文件:

#import

//1.聲明協(xié)議

@protocol SecondViewControllerDelegate

-(void)sendValue:(NSString *)str;

@end

@interface SecondViewController : UIViewController

@property(nonatomic, retain)NSString *str;

@property(nonatomic, retain)NSArray *arr;

//2.設(shè)置代理人屬性@property(nonatomic, assign)iddelegate;

//block傳值

@property(nonatomic, copy)void(^block)(void);

@end

后一個(gè)界面SecondViewController.m文件:

#import "SecondViewController.h"

@interface SecondViewController ()

@property(nonatomic, retain)UITextField *text;

@end

@implementation SecondViewController

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view.

self.view.backgroundColor = [UIColor whiteColor];

NSLog(@"%@", self.str);

self.title = self.str;

NSLog(@"%@", self.arr);

UIButton *btn = [UIButton buttonWithType:UIButtonTypeSystem];

btn.backgroundColor = [UIColor redColor];

[self.view addSubview:btn];

btn.frame = CGRectMake(100, 100, 200, 50);

btn.layer.borderWidth = 1;

btn.layer.cornerRadius = 5;

[btn setTitle:@"返回" forState:UIControlStateNormal];

[btn addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];

self.text = [[UITextField alloc]initWithFrame:CGRectMake(100, 200, 200, 50)];

self.text.backgroundColor = [UIColor blueColor];

[self.view addSubview:self.text];

[_text release];

self.text.layer.borderWidth = 1;

self.text.layer.cornerRadius = 5;

}

-(void)click:(UIButton *)button{

[self.navigationController popViewControllerAnimated:YES];

//3.觸發(fā)協(xié)議生效

[self.delegate sendValue:self.text.text];

//調(diào)用block

self.block();

[[NSNotificationCenter defaultCenter]postNotificationName:@"text" object:nil userInfo:@{@"name":@"james"}];

}

運(yùn)行結(jié)果如下:


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者

  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子功蜓,更是在濱河造成了極大的恐慌,老刑警劉巖吨枉,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件混埠,死亡現(xiàn)場離奇詭異,居然都是意外死亡鹏浅,警方通過查閱死者的電腦和手機(jī)嗅义,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來隐砸,“玉大人之碗,你說我怎么就攤上這事〖鞠#” “怎么了褪那?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長式塌。 經(jīng)常有香客問我博敬,道長,這世上最難降的妖魔是什么峰尝? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任偏窝,我火速辦了婚禮,結(jié)果婚禮上武学,老公的妹妹穿的比我還像新娘祭往。我一直安慰自己,他們只是感情好劳淆,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布链沼。 她就那樣靜靜地躺著,像睡著了一般沛鸵。 火紅的嫁衣襯著肌膚如雪括勺。 梳的紋絲不亂的頭發(fā)上缆八,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天,我揣著相機(jī)與錄音疾捍,去河邊找鬼奈辰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛乱豆,可吹牛的內(nèi)容都是我干的奖恰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼宛裕,長吁一口氣:“原來是場噩夢啊……” “哼瑟啃!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起揩尸,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蛹屿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后岩榆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體错负,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年勇边,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了犹撒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,977評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡粒褒,死狀恐怖识颊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情奕坟,我是刑警寧澤谊囚,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站执赡,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏函筋。R本人自食惡果不足惜沙合,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望跌帐。 院中可真熱鬧首懈,春花似錦、人聲如沸谨敛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽脸狸。三九已至最仑,卻和暖如春藐俺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背泥彤。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工欲芹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吟吝。 一個(gè)月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓菱父,卻偏偏與公主長得像,于是被迫代替她去往敵國和親剑逃。 傳聞我的和親對象是個(gè)殘疾皇子浙宜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容