iOS 开发可视化编程之Storyboard 简述

Storyboard是苹果在iOS5中引入的新技术,目的是更加直观的展示复杂的nib和xib.

First

在上篇文章中已经讲过,Storyboard是一个资源文件,它的本质是一个xml格式的文件,在iOS 开发可视化编程之Xib 简述已经说明.

Storyboard本质

Storyboard是强大的,他给我们提供了一种全新的页面跳转方式segue,并且它对cell的支持更加强大.

A important essence

当我创建出一个空的iOS项目的时候,实际上它是以初始化storyboard文件作为程序的入口的.而ViewController实际上是绑定了storyboard的.所以在上一篇iOS 开发可视化编程之Xib 简述我们以初始化xib的RootViewController文件作为程序入口的时候我们删掉了Main.storyboard文件并且将Main interface中的Main删掉了.

Main interface

此外,我们也可以从info.plist文件中查看

info.plist

The simple use of Storyboard

其实我们可以通俗的将storyboard理解为加强版的xib,它是n个xib的组合.但是storyboard只能被VC的子类使用,也就是说我们只能网其中拖VC,而View的展示必须依赖VC展示.

关于标签下属性的设置已经在iOS 开发可视化编程之Xib 简述中说明了,请大家移步.

The focus of this article

本文关于storyboard主要介绍segue和storyboard对cell的支持

同样我们还是以模拟需求的方式来说明其应用,我们依然模拟登陆界面.

这次我们在登陆界面设置导航视图控制图,点击登陆跳转到一个UITableViewController,我们添加一个注册按钮,点击注册按钮跳转到一个UIViewController.

设置UINavigationController

我们通过点击任务栏中的Editor设置UINavigationController.

设置导航视图控制器

不知道大家注意没有,当我们设置完UINavigationController之后,原本指向ViewController的箭头现在指向了UINavigationController.

is Initial View Controller

这个箭头其实就是 "is initial View Controller" 他表征了这个控制器是storyboard的初始控制器.程序开始启动storyboard首先呈现的就是这个控制器.

那么如果我们不设置"is initial View Controller"的话就会出现找不到初始控制器(其实也就是根视图控制器),就会出现黑屏的状况.

黑屏

我们在添加完UINavigationController之后就会在ViewController上显示出来,这时候我们双击ViewController的NavigationController中间的部分就可以设置Navigation Item了.

设置navigation Item

设置界面UI

这个界面很简单,我们只需要添加两个Label,两个TextField,两个Button就可以了,关于添加的方式,以及autoLayout的添加方式已经在iOS 开发可视化编程之Xib 简述说过,其实是一样的.在此就不在赘述.

UI搭建

点击"注册"按钮跳转页面

我们在storyboard中拖入一个ViewController模拟,点击"注册"按钮跳转到的页面.在这里我们选择push的跳转方式,其实跳转的方式还可以使用模态来进行,请大家自己试验.

跳转

我们创建一对类文件与拖入storyboard的ViewController关联,关联方式在
iOS 开发可视化编程之Xib 简述中已经说明.

我们取名为RegisterViewController.

选择"注册"按钮按住Control键拖到控制器.我们会看到两个控制器中间出现了像串着纽扣似的一条线,这就是segue.

为了标记我们设置RegisterViewController的Navigation Item为"注册",并且为控制器设置一个颜色.

这样就实现了页面的跳转,可是虽然实现了跳转,但是页面之间的传值怎么办呢?

关于传值

使用segue传值,就必须在类文件中判断出segue连接的是哪两个控制器.我们点击对应的segue,然后使用"show the Attributes inspector"标签下的identifier来标记segue.

用identifier标记segue

storyBoard在视图控制器之间相互切换,系统会自动执行如下方法,页面间传值,必须写在此方法里面.

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

在这里我们就模拟,将ViewController中"用户名"UITextField中输入的字传给RegisterViewController中的一个Label.

首先,在RegisterViewController中拖一个Label,设置颜色,并且在.m文件中将其拖成属性.同时在.h文件中创建一个NSString类型的属性.在ViewController的类文件中将"用户名"这个textField也拖成属性.

在RegisterViewController.h中:

@property (nonatomic, strong) NSString *string;

由于是要在ViewController中将文字传给RegisterViewController,那么我们在ViewController中实现上述方法.

-(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender{
    // 先获取连线的标识符identfier
    if ([segue.identifier isEqualToString:@"registerPush"]) {
        
        // 获取源控制器
        ViewController *VC = segue.sourceViewController;
        
        // 获取目标控制器
        RegisterViewController *registerVC = segue.destinationViewController;

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

效果如下:

传值

点击"登陆"按钮跳转页面

同样我们在storyboard中拖入一个ViewController,不过这次我们为了展示storyboard对cell的支持,我们拖入一个UITableViewController,并且创建类文件,用同样的方式进行关联.

****注:写到这里,我想说一下关于storyboard文件的使用****

我们可以从我们演示的例子中看到storyboard与ViewController是一对多的关系.那么我们怎么从storyboard找到某一个ViewController呢?

我们使用 "show the identity inspector"标签下的 Identity 的storyboardID来标记区分.

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

这样我们在类文件中就可以使用一下代码访问到了.

在这里我们为了演示使用storyboardID来查找VC,我们使用代码来演示界面的跳转.

首先,我们先将登陆按钮的触发事件拖成方法.然后在这个方法里写如下代码

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

这样就可一跳到LoginTableViewController中了.

在LoginTableViewController中设置cell

我们可以直接在LoginTableViewController中对cell进行设置.

现在我们假使要在tableVC中展示一个如下界面:

示例

我们直接在在tableVC的Prototype cells中拖入一个Label一个UIImageView并添加约束即可.

然后创建一对继承于UITableViewCell的类文件,与Prototype cells关联,并设置cell的重用标识符identifier.

storyboard设置identifier:

设置identifier

将label和imageView在cell的类文件中关联成属性

关联成属性

最后设置tableVC就可以了,关于tableVC的设置就不在赘述,tableView的想过请移步,
iOS 开发可视化编程之Xib 简述.

声明一点,我们不在需要在重用池中注册cell了,也不用设置重用标识符了,因为我们在storyboard里面已经完成过相关操作了.

点击cell跳转到详情页

最后我们在做一个跳转,点击cell跳转到详情页面,使用storyboard实现,不再使用

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

同样的拖一个VC控制器到storyboard,创建类文件DetailViewController与storyboard文件关联.在类的.h文件中声明一个NSString属性.

@property(nonatomic,strong)NSString *string;

在storyboard中按住Control将cell拖到DetailViewController中,设置跳转方式,在这里我依然选择push,因为我要将cell中nameLab上的文字作为DetailViewController的navigation Items.

push跳转

关于传值,我们在tableVC中使用如下方法进行传值

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
//     Get the new view controller using [segue destinationViewController].
//     Pass the selected object to the new view controller.
    
    // 首先获取当前点击的路径
    NSIndexPath *indexPath = [self.tableView indexPathForCell:sender];
    
    // 获取目标控制器
    DetailViewController *detailVC = segue.destinationViewController;
    
    // 传值
    detailVC.string = _nameArray[indexPath.row];
    
}

在DetailViewController中设置:

self.title = _string;

这样我们就完成了点击cell进行页面的跳转.

****注:说明一点****

尽管我们在上述需求完成过程中并没有使用到

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

这个方法,但是程序在执行点击跳转的时候还是会走这个方法.

我们可以通过在

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

方法中打印一句话的方式进行检验,在这里就不再操作了,读者有兴趣可以自己试验.

结束

End

以上就是关于在可视化编程中storyboard的使用简述,由于笔者的水平有限,难免会出现问题,如果有疑惑或者错误,欢迎交流指正,我将不胜感激.另,转载请保留链接.

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

推荐阅读更多精彩内容