Swift开发--Storyboard的使用教程

原创 2015年07月10日 17:49:05

如果App中包括很多不同的页面,使用Storyboard可以帮你减少实现页面间跳转的胶合代码。过去的开发者对应每个视图控制器分别创建界面设计文件(即“nib”或“xib”文件),现在,只要一个Storyboard就可以包揽所有视图控制器的界面设计和他们之间的关联。

Storyboard有很多优点:

  • 使用Storyboard可以更好地了解App中所有的视图以及它们之间的关联的概况。掌控全局更加容易,因为所有的设计都包含在一个文件中,而不是分散在很多单独的nib文件中。

  • Storyboard可以描述不同视图之间的过渡,这种过渡叫做“segue”(译注:意为“转场”,而“Storyboard”原意为“分镜”,均源自电影术语),你可以直接在Storyboard中通过连接不同的视图控制器来创建转场。多亏有了转场,打理界面的代码比以前要少了。

  • Storyboard通过新的原型表项(prototype cell)和静态表项(static cell)特性,让处理表视图(table view)的工作更加轻松。几乎完全可以在Storyboard编辑器里搞定表视图的设计,同样也减少了代码量。

  • Storyboard使自动布局(Auto Layout)更易用。自动布局功能可以让你通过界面元素之间的数学关系定义来确定元素的位置和尺寸,极大简化了不同尺寸屏幕的适配工作。自动布局不在本教程范围之内,若想了解更多,请参阅自动布局入门

如果你非常讨厌Interface Builder,或者推崇用代码搞定所有界面的话,Storyboard可能不适合你。个人主张是代码能少写就少写,特别是UI代码,所以Storyboard简直就是为我准备的一把利器。

如果你想继续使用nib,那就继续用吧,要知道Storyboard里是可以使用nib的,两者并非互斥关系。

效果图:

1、打开Xcode,创建新项目,语言选择swift。

2、在当前Storyboard的 File inspector(文件检查器) 中禁用Auto Layout和Size Classes。

3、在Main.storyboard 中把原先的视图控制器删掉。

4、把一个 Tab Bar Controller(分页栏控制器) 从对象库拖到面板中。点击空白区域可以放大缩小视图。

5、运行。这时会发现报错。

Failed to instantiate the default view controller for UIMainStoryboardFile 'Main' - perhaps the designated entry point is not set?

未设置入口,也就是刚才删除最先使用的那个场景之后没设置初始视图控制器。为解决问题,选中这个分页栏控制器,然后在 Attributes Inspector(属性检查器) 中选定 Is Initial View Controller 。

6、再次运行ok了。


相关文章推荐

Swift教程_零基础学习Swift完整实例(四)_swift完整实例(搭建程序结构、构建storyboard)

swift重写Sample 本章开始进入正题,笔者将分搭建程序结构、构建storyboard、构建数据层、构建展示层、构建控制层、添加View的阴影、添加View的动画效果七个部分来对官方Sampl...

Swift官方入门教程系列--二--storyboard与代码的交互【翻译版,源代码】

本系列是Swift官方入门教程的翻译版,含源码,欢迎一起学习Swift。

Swift语言Storyboard教程:第一部分

更新记录: 该Storyboard教程由Caroline Begbie更新iOS 8和Swift相关内容。原文作者为教程编纂组的成员Matthijs Hollemans。 2014/12/10更...
  • lm16875
  • lm16875
  • 2016年07月06日 13:50
  • 304

Swift教程_swift常见问题(0003)_storyboard修改不生效

使用swift与objC在xcode中开发时均会碰到一个问题,从别的地方cop

swift中UITableView的基本使用(基于Storyboard):适用新手

第一步 在storeboard里 给你的viewcontroller拖入Table View,如图 第二步: 继续拖入Table View Cell 第三步:设置你的cell样式,即你...

Swift - 使用addSubview()方法将StoryBoard中的视图加载进来

Swift - 使用addSubview()方法将StoryBoard中的视图加载进来

swift 自定义控件在StoryBoard(xib)里使用的属性

有时候我们在StoryBoard里用拖拽方法创建属性的时候,总会有一些常用的属性没有提供可视化操作,所以我们必须在连接类中用代码去实现,虽然也比较简单,但是这样重复的操作大大的增加了开发时间,如果能在...

Swift使用Main.storyboard的segue值来回传数据

在正文之前我不得吐槽一下,学新语言真是太坑太坑了,如果是纯新手或者仅仅觉得这个行业工资高而转战的千万不要选新的语言!!我其实主要是想学JAVA做服务端的,然后选了个ios作为我的客户端来展示,然后直接...

iOS开发教程:Storyboard全解析

  • 2014年05月29日 14:10
  • 3.62MB
  • 下载

iOS开发教程:Storyboard全解析2

  • 2014年05月29日 14:10
  • 1.54MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Swift开发--Storyboard的使用教程
举报原因:
原因补充:

(最多只允许输入30个字)