首页 > 代码库 > swift - storyboard(故事版)的使用
swift - storyboard(故事版)的使用
iOS开发中,苹果公司提供了一种可视化的编程方式:即xib和storyboard,xib相对来说比较灵活,可以在纯代码的项目中使用,
也可以和storyboard配合使用,用法都差不多,下面来总结一下故事版的使用方法:
1,初始
选中viewcontrolller,在属性面板里勾选Is Initial View Controller,即可设置为其实场景,前面会有灰色的小箭头
2,将viewconroller的尺寸改成iPhone的大小
3,添加segue
使用segue的好处是,页面的千幻不在需要创建任何代码,按住ctrl键同事Tod‘s空间到目标场景,在弹出的上下文菜单中选择show
1)菜单中间4个是过去版本的使用方式,推荐最上面的4个新的方式:
Show:就是Push一个新的视图
Show Detail:替换当前的视图方式来展现新的视图
Modally:模式窗口的方式
Popover:浮窗形式
2)如果两个Controller之间建立包含关联,例如从TableBarController到NavigationController,则上下文菜单会有relationship的选项,选择viewcontroller即可。
4,给segue添加关联类
在storyboard中添加一个segue时并不会同步添加对应的类,如果需要,得手动添加!
5,添加关联代码
主要有两种关联类型,一种是outlet连接,就是在代码里面创建界面元素的成员变量引用,另一种是Action时间,把界面元素的相应时间方法添加到代码里来。
6,同一个storyboard里多个View Controller的引用
var rootViewController = UIStoryboard(name: "Main", bundle: nil) .instantiateViewControllerWithIdentifier("RootView") as UIViewController
对于初始Viewcontroller也可以不通过identity直接换区:
var rootViewController = UIStoryboard(name: "Main", bundle: nil) .instantiateInitialViewController() as UIViewController
7,使用多个storyboard文件
一个项目可以不止一个storyboard文件,他们之间也可以互相调用,假如还添加一个XXX.storyboard,里面的viewcontroller设置identity为secondView,则我们可以通过导航的方式来关联两个storyboard文件。
在AppDelegate的Application入口里把Main面板放入导航控制:
var rootViewController = UIStoryboard(name: "Main", bundle: nil) .instantiateInitialViewController() as UIViewController self.window!.rootViewController = UINavigationController(rootViewController: rootViewController)
然后可以在RootView里放入一个安润,点击事件里导航到想要去的页面:
var viewController = UIStoryboard(name: "Second", bundle: nil) .instantiateViewControllerWithIdentifier("SecondView") as UIViewController self.navigationController?.pushViewController(viewController, animated: true)
swift - storyboard(故事版)的使用