Swift中页面跳转与传值:
1.简单方式
首先,Swift的跳转可分为利用xib文件跳转与storyboard跳转两种方法,我这里选择使用storyboard的界面跳转方法。
1、通过在storyboard中拉button控件建立segue跳转。
2、通过presentViewController方法进行界面跳转。
这里需要注意presentViewController方法适用于xib与storyboard两种方法,但是当使用storyboard直接调用该方法时,ios模拟器会转入一个黑屏界面,程序不会报错。
主要原因是storyboard制作页面和手写页面,需要使用两种不同的方法来进行页面跳转。
对于storyboard制作页面:
var sb = UIStoryboard(name: "Main", bundle:nil)
var vc = sb.instantiateViewControllerWithIdentifier("myViewController") as MyViewController
self.presentViewController(vc, animated: true, completion: nil)
对于手写页面:
var vc = MyViewController()
self.presentViewController(vc, animated: true, completion: nil)
seuge跳转除了连线方式还有另外一种方法:
performSegueWithIdentifier("SecondSegue", sender: self)
其中利用sugue传值代码如下:
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
var des = segue.destinationViewController as! ViewController
des.label = textF
}
2.利用协议protocol进行传值
协议protocol指的是在类之间制定一套规定进行委托执行,一个类可以通过协议委托另外一个类执行方法
protocol正向传值
写好协议:
protocol ParamsProtocol{
//协议中得方法不能有结构体
func returnParams(tmpStr: String)
}
ViewController:
var paramsProtocolDelegate: ParamsProtocol?
//定义一个方法给协议中得方法赋值
//在viewController中实现方法,这样在btn1,btn2中就可以不用实现,帮他们2个实现了.这就是代理.
func start(){
self.tmpString = "通过delegate进行的值传递方式2"
self.paramsProtocolDelegate?.returnParams(self.tmpString)
}
在NextViewcontroller中:
//遵守协议必须重新实现一下协议中得方法
func returnParams(tmpStr: String) {
self.text2.text = tmpStr
}
override func viewDidLoad() {
super.viewDidLoad()
obj.paramsProtocolDelegate = self
obj.start()
// Do any additional setup after loading the view, typically from a nib.
}
4.利用NSUserDefaults进行传值
NSUserDefaults能实现小容量的数据存储功能,常用于用户名密码保留等功能上,也可以用来传值。
创建一个工具类:
import Foundation
//工具类,放置一些经常用到的方法
//通过userDefault存储数据
class baseClass{
func cacheSetString(key: String,value: String){
let userInfo = NSUserDefaults()
userInfo.setValue(value, forKey: key)
}
func cacheGetString(key: String) -> String{
let userInfo = NSUserDefaults()
let tmpSign = userInfo.stringForKey(key)
return tmpSign!
}
}
ViewController:
var base: baseClass = baseClass()
}
@IBAction func btn3Click(sender: AnyObject) {
self.base.cacheSetString("sign", value: "通过NSUserDefaults传递方式3")
self.performSegueWithIdentifier("btn3", sender: self)
}
NextViewController:
@IBOutlet weak var text3: UITextField!
var base: baseClass = baseClass()
var sign:String = String()
override func viewDidLoad() {
super.viewDidLoad()
self.sign = base.cacheGetString("sign")
text3.text = self.sign
// Do any additional setup after loading the view, typically from a nib.
}
补充两种:
4. 利用 self.storyboard
利用 self.storyboard 方法, 就不需要进行 连线, 一样可以进行视图之间的跳转. 但是必须要设置 Storyboard ID.
然后利用 如下方法进行 跳转 和 传值
var thirdVC = self.storyboard?.instantiateViewControllerWithIdentifier("ThirdViewController") as ThirdViewController
thirdVC.text = "Pass"
self.navigationController?.pushViewController(thirdVC, animated: true)
因为是在 同一个 Storyboard 里面进行跳转, 所以 self.storyboard 就可以满足需求.
不明白? 看最后一个方法:
5. 利用 UIStoryboard
XIB 方法, 我们需要 用到 nibName, 同样 如果我们想要 分离多个 sence 在不同的Storyboard 里面, 怎么办?
这个时候, 就不能使用 self.storyboard 了.
而是:
var storyboard = UIStoryboard(name: "New", bundle: nil)
var newVC = storyboard.instantiateViewControllerWithIdentifier("NewViewController") as NewViewController
newVC.text = "Pass"
self.navigationController?.pushViewController(newVC, animated: true)
是不是 和 XIB 有异曲同工的感觉, 这样就可以把 Storyboard 分几个, 每个里面放几个 Sence.
这样的好处就是, 当你需要做多个不同功能的模块的应用, 分离到不同的 Storyboard 中, 彼此互不影响.
相对于 XIB 来说, 每个文件夹 只需要 1 个 Storyboard 文件, 和 Swfit 文件就可以了.