UIStoryboard跳转及传值(3)
*首先自己新建一个工程并搭建如下框架
89147FAA-FF36-4B60-AB94-A885B1AF0766.png
-
UIButton和静态Cell直接跳转 可以点住按钮或Cell并按control将线拉倒需要跳转到的VC,会弹出一个选择框,Selection Segue和Accessory Action,这2部分的选项是相同的。 -
Selection Segue的意思是当用户点击table view cell的任何部分,都会产生反应。 -
Accessory Action的意思是只有当用户点击table view cell右边的圆圈箭头按钮时,才会产生的反应。 -
下面2个
Non-Adaptive Selection Segue和Non-Adaptive Accessory Segue几个方法都被标记为deprecated(不赞成的),这个是从Xcode6开始废弃的,在iOS8之后将不会有效。
C2E049CD-8569-42C5-A2F0-C836CBEDBF1C.png
-
选中
Segue,选中如图菜单
F42D81FD-3516-4807-83E6-65087DD6CD76.png
-
Identifer为Segue跳转的标识,在我们需要传值的时候,需要从VC拉线到VC,而不是直接从UIButton或者静态Cell拖线跳转。我们可以调用
performSegue(withIdentifier: "asd", sender: nil)
进行界面跳转,当然跳转方式已经在SB中表示了,所以这里的所有跳转操作都由同一个函数来表示,而不需要区分不同跳转方式。
这个函数有个对应的回调方法
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
let ide = segue.identifier
if ide == "asd" {
print(segue.destination)
print(segue.source)
let oneVC = segue.destination as! OneViewController
oneVC.str = "123"
}
}
-
我们可以根据
segue.identifier来获取当前的跳转,我们可以根据segue.destination获取到当前所要跳转到的VC,segue.source获取当前推出VC的VC。将segue.destination进行强转,我们就可以给所需要推出的VC赋值,并进行了传值。当然获取到推出的控制器我们还可以在子控制器定义Block进行反向传值,这里就不细说了。 -
Class我们可以t通过继承UIStoryboardSegue并重写perform来进行自定义跳转
override func perform() {
let src = self.source
let dst = self.destination
src.navigationController?.pushViewController(dst, animated: true)
}
-
Kind当你选择跳转方式选错了的时候,可以通过修改这里修改跳转方式。 -
Animates勾选会有跳转动画效果,反之则没有 -
Peek & Pop这个和3D Touch预览以及跳转相关,感兴趣的可以自己试试。这里就不细讲。 -
跳转之
Embed Segue,这个功能很吊的。我们可以通过向A VC里面拖一个Container View再向一个B VC拉线,并选择Embed。这个B VC就会像一个View一样显示在Container View里面。这样可以放置TableVC。在SB中TableVC也是很吊的,我们可以完全只靠TableVC写出一个完整APP而不使用VC... 关于这两个东西为何吊,这里就不讲了,后面的章节将会讲到。这个的传值以及回调可以参照上面的。
9DAC9F21-B934-49CE-A62C-222581B592DF.png
-
选中VC我们可以看到如下视图
28351CBE-C494-4936-B1A3-BAF20444C228.png
-
Class就不讲了。 -
Module这个也不讲,这个主要是多target的时候使用。 -
StoryBoard ID设置这个ID之后我们可以根据SB名称和ID获取到这个VC并进行相应的操作。设置这个ID有个小技巧,我们可以设置为和Class名称一样,一个好处: 可以做到不同命,不产生冲突,利于不好取名和代码获取ID的时候不用手写并导致的错误。 -
获取Storyboard
+ (UIStoryboard *)storyboardWithName:(NSString *)name bundle:(NSBundle *)storyboardBundleOrNil -
获取初始控制器
- (id)instantiateInitialViewController -
找到对应的控制器,这里参数就是 StoryBoard ID
- (id)instantiateViewControllerWithIdentifier:(NSString *)identifier; -
Restoration ID是系统进入后台或者应用被终止,app重新起来时的用于恢复时使用。 -
Use Storyboad ID就是让Restoration ID使用Storyboad ID这个命名。
end---