iOS 開發(fā)可視化編程之Storyboard 簡(jiǎn)述

Storyboard是蘋果在iOS5中引入的新技術(shù),目的是更加直觀的展示復(fù)雜的nib和xib.

First

在上篇文章中已經(jīng)講過,Storyboard是一個(gè)資源文件,它的本質(zhì)是一個(gè)xml格式的文件喇嘱,在iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述已經(jīng)說明.

Storyboard本質(zhì)

Storyboard是強(qiáng)大的,他給我們提供了一種全新的頁面跳轉(zhuǎn)方式segue,并且它對(duì)cell的支持更加強(qiáng)大.

A important essence

當(dāng)我創(chuàng)建出一個(gè)空的iOS項(xiàng)目的時(shí)候,實(shí)際上它是以初始化storyboard文件作為程序的入口的.而ViewController實(shí)際上是綁定了storyboard的.所以在上一篇iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述我們以初始化xib的RootViewController文件作為程序入口的時(shí)候我們刪掉了Main.storyboard文件并且將Main interface中的Main刪掉了.

Main interface

此外,我們也可以從info.plist文件中查看

info.plist

The simple use of Storyboard

其實(shí)我們可以通俗的將storyboard理解為加強(qiáng)版的xib,它是n個(gè)xib的組合.但是storyboard只能被VC的子類使用,也就是說我們只能網(wǎng)其中拖VC,而View的展示必須依賴VC展示.

關(guān)于標(biāo)簽下屬性的設(shè)置已經(jīng)在iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述中說明了,請(qǐng)大家移步.

The focus of this article

本文關(guān)于storyboard主要介紹segue和storyboard對(duì)cell的支持

同樣我們還是以模擬需求的方式來說明其應(yīng)用,我們依然模擬登陸界面.

這次我們?cè)诘顷懡缑嬖O(shè)置導(dǎo)航視圖控制圖,點(diǎn)擊登陸跳轉(zhuǎn)到一個(gè)UITableViewController,我們添加一個(gè)注冊(cè)按鈕,點(diǎn)擊注冊(cè)按鈕跳轉(zhuǎn)到一個(gè)UIViewController.

設(shè)置UINavigationController

我們通過點(diǎn)擊任務(wù)欄中的Editor設(shè)置UINavigationController.

設(shè)置導(dǎo)航視圖控制器

不知道大家注意沒有,當(dāng)我們?cè)O(shè)置完UINavigationController之后,原本指向ViewController的箭頭現(xiàn)在指向了UINavigationController.

is Initial View Controller

這個(gè)箭頭其實(shí)就是 "is initial View Controller" 他表征了這個(gè)控制器是storyboard的初始控制器.程序開始啟動(dòng)storyboard首先呈現(xiàn)的就是這個(gè)控制器.

那么如果我們不設(shè)置"is initial View Controller"的話就會(huì)出現(xiàn)找不到初始控制器(其實(shí)也就是根視圖控制器),就會(huì)出現(xiàn)黑屏的狀況.

黑屏

我們?cè)谔砑油闡INavigationController之后就會(huì)在ViewController上顯示出來,這時(shí)候我們雙擊ViewController的NavigationController中間的部分就可以設(shè)置Navigation Item了.

設(shè)置navigation Item

設(shè)置界面UI

這個(gè)界面很簡(jiǎn)單,我們只需要添加兩個(gè)Label,兩個(gè)TextField,兩個(gè)Button就可以了,關(guān)于添加的方式,以及autoLayout的添加方式已經(jīng)在iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述說過,其實(shí)是一樣的.在此就不在贅述.

UI搭建

點(diǎn)擊"注冊(cè)"按鈕跳轉(zhuǎn)頁面

我們?cè)趕toryboard中拖入一個(gè)ViewController模擬,點(diǎn)擊"注冊(cè)"按鈕跳轉(zhuǎn)到的頁面.在這里我們選擇push的跳轉(zhuǎn)方式,其實(shí)跳轉(zhuǎn)的方式還可以使用模態(tài)來進(jìn)行,請(qǐng)大家自己試驗(yàn).

跳轉(zhuǎn)

我們創(chuàng)建一對(duì)類文件與拖入storyboard的ViewController關(guān)聯(lián),關(guān)聯(lián)方式在
iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述中已經(jīng)說明.

我們?nèi)∶麨镽egisterViewController.

選擇"注冊(cè)"按鈕按住Control鍵拖到控制器.我們會(huì)看到兩個(gè)控制器中間出現(xiàn)了像串著紐扣似的一條線,這就是segue.

為了標(biāo)記我們?cè)O(shè)置RegisterViewController的Navigation Item為"注冊(cè)",并且為控制器設(shè)置一個(gè)顏色.

這樣就實(shí)現(xiàn)了頁面的跳轉(zhuǎn),可是雖然實(shí)現(xiàn)了跳轉(zhuǎn),但是頁面之間的傳值怎么辦呢?

關(guān)于傳值

使用segue傳值,就必須在類文件中判斷出segue連接的是哪兩個(gè)控制器.我們點(diǎn)擊對(duì)應(yīng)的segue,然后使用"show the Attributes inspector"標(biāo)簽下的identifier來標(biāo)記segue.

用identifier標(biāo)記segue

storyBoard在視圖控制器之間相互切換,系統(tǒng)會(huì)自動(dòng)執(zhí)行如下方法,頁面間傳值,必須寫在此方法里面.

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(nullable id)sender NS_AVAILABLE_IOS(5_0);

在這里我們就模擬,將ViewController中"用戶名"UITextField中輸入的字傳給RegisterViewController中的一個(gè)Label.

首先,在RegisterViewController中拖一個(gè)Label,設(shè)置顏色,并且在.m文件中將其拖成屬性.同時(shí)在.h文件中創(chuàng)建一個(gè)NSString類型的屬性.在ViewController的類文件中將"用戶名"這個(gè)textField也拖成屬性.

在RegisterViewController.h中:

@property (nonatomic, strong) NSString *string;

由于是要在ViewController中將文字傳給RegisterViewController,那么我們?cè)赩iewController中實(shí)現(xiàn)上述方法.

-(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender{
    // 先獲取連線的標(biāo)識(shí)符identfier
    if ([segue.identifier isEqualToString:@"registerPush"]) {
        
        // 獲取源控制器
        ViewController *VC = segue.sourceViewController;
        
        // 獲取目標(biāo)控制器
        RegisterViewController *registerVC = segue.destinationViewController;

        // 傳值
        registerVC.string = VC.usernameTF.text;
        
    }
    
}

效果如下:

傳值

點(diǎn)擊"登陸"按鈕跳轉(zhuǎn)頁面

同樣我們?cè)趕toryboard中拖入一個(gè)ViewController,不過這次我們?yōu)榱苏故緎toryboard對(duì)cell的支持,我們拖入一個(gè)UITableViewController,并且創(chuàng)建類文件,用同樣的方式進(jìn)行關(guān)聯(lián).

****注:寫到這里,我想說一下關(guān)于storyboard文件的使用****

我們可以從我們演示的例子中看到storyboard與ViewController是一對(duì)多的關(guān)系.那么我們?cè)趺磸膕toryboard找到某一個(gè)ViewController呢?

我們使用 "show the identity inspector"標(biāo)簽下的 Identity 的storyboardID來標(biāo)記區(qū)分.

![storyboardID](http://upload-images.jianshu.io/upload_images/1230517-d8b6ee666c08992f.png)

這樣我們?cè)陬愇募芯涂梢允褂靡幌麓a訪問到了.

在這里我們?yōu)榱搜菔臼褂胹toryboardID來查找VC,我們使用代碼來演示界面的跳轉(zhuǎn).

首先,我們先將登陸按鈕的觸發(fā)事件拖成方法.然后在這個(gè)方法里寫如下代碼

- (IBAction)LoginAction:(UIButton *)sender {
    
    LoginTableViewController *loginVC = [[UIStoryboard storyboardWithName:@"Main" bundle:[NSBundle mainBundle]] instantiateViewControllerWithIdentifier:@"loginPush"];
    [self.navigationController pushViewController:loginVC animated:YES];
    
}

這樣就可一跳到LoginTableViewController中了.

在LoginTableViewController中設(shè)置cell

我們可以直接在LoginTableViewController中對(duì)cell進(jìn)行設(shè)置.

現(xiàn)在我們假使要在tableVC中展示一個(gè)如下界面:

示例

我們直接在在tableVC的Prototype cells中拖入一個(gè)Label一個(gè)UIImageView并添加約束即可.

然后創(chuàng)建一對(duì)繼承于UITableViewCell的類文件,與Prototype cells關(guān)聯(lián),并設(shè)置cell的重用標(biāo)識(shí)符identifier.

storyboard設(shè)置identifier:

設(shè)置identifier

將label和imageView在cell的類文件中關(guān)聯(lián)成屬性

關(guān)聯(lián)成屬性

最后設(shè)置tableVC就可以了,關(guān)于tableVC的設(shè)置就不在贅述,tableView的想過請(qǐng)移步,
iOS 開發(fā)可視化編程之Xib 簡(jiǎn)述.

聲明一點(diǎn),我們不在需要在重用池中注冊(cè)cell了,也不用設(shè)置重用標(biāo)識(shí)符了,因?yàn)槲覀冊(cè)趕toryboard里面已經(jīng)完成過相關(guān)操作了.

點(diǎn)擊cell跳轉(zhuǎn)到詳情頁

最后我們?cè)谧鲆粋€(gè)跳轉(zhuǎn),點(diǎn)擊cell跳轉(zhuǎn)到詳情頁面,使用storyboard實(shí)現(xiàn),不再使用

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;

同樣的拖一個(gè)VC控制器到storyboard,創(chuàng)建類文件DetailViewController與storyboard文件關(guān)聯(lián).在類的.h文件中聲明一個(gè)NSString屬性.

@property(nonatomic,strong)NSString *string;

在storyboard中按住Control將cell拖到DetailViewController中,設(shè)置跳轉(zhuǎn)方式,在這里我依然選擇push,因?yàn)槲乙獙ell中nameLab上的文字作為DetailViewController的navigation Items.

push跳轉(zhuǎn)

關(guān)于傳值,我們?cè)趖ableVC中使用如下方法進(jìn)行傳值

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
//     Get the new view controller using [segue destinationViewController].
//     Pass the selected object to the new view controller.
    
    // 首先獲取當(dāng)前點(diǎn)擊的路徑
    NSIndexPath *indexPath = [self.tableView indexPathForCell:sender];
    
    // 獲取目標(biāo)控制器
    DetailViewController *detailVC = segue.destinationViewController;
    
    // 傳值
    detailVC.string = _nameArray[indexPath.row];
    
}

在DetailViewController中設(shè)置:

self.title = _string;

這樣我們就完成了點(diǎn)擊cell進(jìn)行頁面的跳轉(zhuǎn).

****注:說明一點(diǎn)****

盡管我們?cè)谏鲜鲂枨笸瓿蛇^程中并沒有使用到

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;

這個(gè)方法,但是程序在執(zhí)行點(diǎn)擊跳轉(zhuǎn)的時(shí)候還是會(huì)走這個(gè)方法.

我們可以通過在

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;

方法中打印一句話的方式進(jìn)行檢驗(yàn),在這里就不再操作了,讀者有興趣可以自己試驗(yàn).

結(jié)束

End

以上就是關(guān)于在可視化編程中storyboard的使用簡(jiǎn)述,由于筆者的水平有限,難免會(huì)出現(xiàn)問題,如果有疑惑或者錯(cuò)誤,歡迎交流指正,我將不勝感激.另,轉(zhuǎn)載請(qǐng)保留鏈接.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末搅荞,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡优训,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門各聘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來揣非,“玉大人,你說我怎么就攤上這事躲因∽倍遥” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵毛仪,是天一觀的道長搁嗓。 經(jīng)常有香客問我,道長箱靴,這世上最難降的妖魔是什么腺逛? 我笑而不...
    開封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮衡怀,結(jié)果婚禮上棍矛,老公的妹妹穿的比我還像新娘。我一直安慰自己抛杨,他們只是感情好够委,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著怖现,像睡著了一般茁帽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屈嗤,一...
    開封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天潘拨,我揣著相機(jī)與錄音,去河邊找鬼饶号。 笑死铁追,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的茫船。 我是一名探鬼主播琅束,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼扭屁,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了涩禀?” 一聲冷哼從身側(cè)響起料滥,我...
    開封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎埋泵,沒想到半個(gè)月后幔欧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體罪治,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丽声,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了觉义。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雁社。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖晒骇,靈堂內(nèi)的尸體忽然破棺而出霉撵,到底是詐尸還是另有隱情,我是刑警寧澤洪囤,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布徒坡,位于F島的核電站,受9級(jí)特大地震影響瘤缩,放射性物質(zhì)發(fā)生泄漏喇完。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一剥啤、第九天 我趴在偏房一處隱蔽的房頂上張望锦溪。 院中可真熱鬧,春花似錦府怯、人聲如沸刻诊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽则涯。三九已至,卻和暖如春冲簿,著一層夾襖步出監(jiān)牢的瞬間是整,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來泰國打工民假, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留浮入,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓羊异,卻偏偏與公主長得像事秀,于是被迫代替她去往敵國和親彤断。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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