摘要: java
在iOS的开发过程当中,不可避免的要设计界面,在android中有xml设置界面和直接使用java代码设置界面控件两种方式,在以前的ios开发中也是相似的有xib文件设置界面及用代码直接设置控件两种方法,但后来又出了一种方式,就是storyboard故事板子,其实storyboard和xib文件很像,最大的不一样之处在于一个xib文件对应一个ViewController视图控制器,而storyboard对应多个,基本一个应用只须要一个storyboard就能够了,再也不须要为每一个控制器建立一个xib文件,从这点上来讲,仍是很方便的,在storyboard中查看各个界面的跳转也很方便,但以前一直使用xib进行开发,对storyboard的使用不太熟悉,今天好好学习了一下其中的界面跳转和传值,用到了Segue这个东西,这里借着例子说明一下。 android
首先建立一个新的工程,这里我建立的是Single View Application,就能够自带故事板了,以下图: ios
建立好后能够在左边文件列表中看到Main.stroyboard,这个就是故事板文件了,由于这里要实现界面跳转,只有自带的一个ViewController不够,咱们再建立一个,command+N键建立一个Cocoa Touch Class。 git
如今文件都建立好了,目录以下: github
咱们选择Main.storyboard,开始建立视图和控件。 app
原始的storyboard中只有一个自带的视图,咱们从右下角在拖一个View Controller上来,如图: ide
新版的Xcode建立的视图会是一个大方型的,要改为正常手机界面大小的haunted,选择视图上方的view controller按钮,在右侧第四个部分中把size设成想要的便可: 学习
如今咱们来为视图添加控件,考虑到咱们的需求,要能辨认当下在哪一个界面,要能够在两个界面跳转,要能够设置和显示要传递的值,那么咱们须要一个标题栏,一个按钮和一个用于编辑和显示的编辑框,从右下方分别拖出Navigation Bar、Button、Text Field放在合适的位置,两个视图控制器都要放,如图: 动画
至此,准备工做,基本作完了,接下来就是使用Segue了。
要在故事板中使用Segue跳转,很是的简单和方便,把鼠标移到第一个视图的按钮上,按住鼠标右键不放,拖动鼠标到第二个视图,松开,而后会出现一个选项框,这里是要选择Segue的模式,咱们选择最下面的modal,会在两个视图中出现一个箭头,表示能够跳转到第二个视图了,就是这么简单,如今运行模拟器跑工程,点击第一个视图的按钮已经能够跳转了,是否是很简单!
刚才说到选择modal,Segue有几种模式,在iPhone上能够用到的有modal、push和custom,其余还有几种是iPad上用的,这里简单说明一下:
一、modal:模态地加载视图控制器,最经常使用的方式,相似present和dismiss;
二、push:使用导航栏压进新的视图控制器,相似push和pop,要使用这个模式,跳转的源视图,也就是这里的Page1必须是Navigation Controller,这里咱们不是,因此选择的话运行起来会报错;
三、custom:用户自定义。
如今咱们选择两个视图控制器中间的箭头线条,右边查看第四个部分,能够看到能够选择一些Segue的属性:
一、Identifier:能够定义Segue的标识,若是一个源视图有不少跳转到其余视图的Segue,就能够靠这个标识来判断究竟是哪一个Segue,后面代码里再说明,这里咱们只有一个跳转因此先不写;
二、Segue:能够选择Segue的模式,好比刚才的modal、push等等;
若是模式是modal,还有以下选项,其余的模式选项不一样:
三、Presentation:还没搞清楚,求大神指教;
四、Transition:跳转界面的方式(Cover Vertical:水平上移切换;Filp Horizontal:从右到左翻转;Cross Dissolve:闪现;Partial Curl:从下往上翻页),能够都试一试。
要从Page2跳回到Page1,可不能像上面同样再拉一个Segue回到Page1的视图,这样在跳转的过程当中,跳一次添加一个新视图,跳一次添加一个新视图,原来的视图都没有消去,会一直累加的,并非回到Page1.
正确的作法是使用dismissViewControllerAnimated: completion:方法来跳回界面。在Page2的视图控制器中,把按钮关联到Page2ViewController中去,而后编辑按钮的响应方法:
咱们在两个视图中都添加了TextField编辑输入框,这样咱们能够在Page1的页面中输入数据来传递到Page2显示,一样的能够在Page2中输入数据回到Page1显示。首先要作的,仍是把两个输入框关联到各自的视图控制器中去。
咱们传值有两种方式,正好在两个传输过程当中使用,先看第一个方法,实现从Page1传值到Page2:
咱们先在Page2中定义一个变量用来接收所传递的值:
PS:上面曾经说到过Segue的属性里有一个Identifier,就是在这个方法中用来判断是哪一个Segue在起做用,如:
如今讲第二种方法,从Page2传回Page1,用协议delegate,关于协议的具体用法能够查找相关资料,这里直接讲怎么使用,简单的直接实现:
首先在Page2的.h文件中,声明协议和协议方法,以及采用协议的物件:
实现协议的方法,设定修改输入框内容为传回来的值:
这样就能够实现Page2往Page1的传值了,运行看看吧~
这里有个人工程源码:https://github.com/Cloudox/SegueTest
转载请注明出处,谢谢
参考资料:
segue分析小结:http://mikixiyou.iteye.com/blog/1745995
使用Storyboard Segue 实做 UIViewController的切换:http://blog.csdn.net/mazhen1986/article/details/7791430