我的项目遇到了一个小问题。我是iOS开发的新手,我遇到了一个小问题,试图传递一些我从JSON格式的响应体中提取的数据。我可以在将它分配给类中的变量后立即从服务器打印出正确的数据,但是一旦我准备并执行了一个segue,它似乎就不会过去了。这是我的第一个viewController:
import UIKit
import SwiftyJSON
class ViewController: UIViewController {
@IBOutlet weak var emailAddress: UITextField!
@IBOutlet weak var userPassword: UITextField!
var returned_email: String!
var returned_pass: String!
var current_exp: Int!
var needed_exp: Int!
@IBAction func getUserDataBtn(_ sender: Any) {
if emailAddress.text != "" && userPassword.text != ""
{
let session = URLSession.shared
let parameters = ["nameValuePairs":["username": emailAddress.text, "password": userPassword.text]]
guard let myURL = URL(string: "<protected url>") else {return}
var request = URLRequest(url: myURL, cachePolicy: URLRequest.CachePolicy.useProtocolCachePolicy, timeoutInterval: 300.0)
request.httpMethod = "POST"
guard let httpBody = try? JSONSerialization.data(withJSONObject: parameters, options: []) else {return}
request.httpBody = httpBody
request.addValue("application/json", forHTTPHeaderField: "Content-Type")
session.dataTask(with: request, completionHandler: { (data, response, error) in
if let myData = data{
do{
let json = try JSONSerialization.jsonObject(with: myData, options: .mutableContainers) as! [String:Any]
self.returned_email = json["username"] as! String
self.returned_pass = json["password"] as! String
self.current_exp = json["curr_exp"] as! Int
self.needed_exp = json["needed_exp"] as! Int
}
catch{
print(error)
}
self.performSegue(withIdentifier: "GetUserDataSegue", sender: self)
}
}).resume()
}
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?){
if(segue.identifier == "GetUserDataSegue"){
guard let viewController = segue.destination as? UserDataController else {return}
viewController.myUN = returned_email
viewController.myPW = returned_pass
viewController.myCurrExp = current_exp
viewController.myNeedExp = needed_exp
}
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
}
}
这是我的另一个viewcontroller:
import UIKit
class UserDataController: UIViewController {
var myUN: String!
var myPW: String!
var myCurrExp: Int!
var myNeedExp: Int!
@IBOutlet weak var password: UILabel!
@IBOutlet weak var username: UILabel!
@IBOutlet weak var current_exp: UILabel!
@IBOutlet weak var needed_exp: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
username.text = myUN
password.text = myPW
current_exp.text = String(describing: myCurrExp)
needed_exp.text = String(describing: myNeedExp)
// Do any additional setup after loading the view.
}
}
我想用这个测试项目来完成的是让一个人输入他们的用户名和密码,点击“获取用户数据”按钮,被带到第二个视图控制器,其所有信息都显示在提供的标签中。我能够从服务器上的数据库中获取正确的数据,并且我能够接收它并将其保存到第一个viewcontroller中的局部变量中。任何帮助,将不胜感激!我正在使用Swift 4和Xcode 9,如果这对答案有任何影响。
感谢您的时间!
答案 0 :(得分:1)
一旦我开始在我的代码中运行断点,我发现一旦离开会话的闭包,我的类变量就不再存储了。我不确定导致这种情况发生的原因
这听起来很像一个错误的身份,即你以某种方式有两个ViewController
的实例,而启动segue的那个实例不是那个是source
视图中的self
视图控制器的实例。由于您在调用sender
时已经为performSegue(withIdentifier:sender:)
参数传递了sender == self
,因此请检查prepare(for:sender:)
中是否Err: Incremental Build failed with Error: java.io.NotSerializableException: java.util.regex.Matcher
。
答案 1 :(得分:0)
在我准备开始之前做了一些关于如何让我的dataTask运行的研究之后,我发现这个小东西帮助我实现了它的工作:
DispatchQueue.main.async {
self.returned_email = json["username"] as! String
self.returned_pass = json["password"] as! String
self.current_exp = json["curr_exp"] as! Int
self.needed_exp = json["needed_exp"] as! Int
self.performSegue(withIdentifier: "GetUserDataSegue", sender: self)
}
通过将DispatchQueue.main.async包装在我的类变量的设置周围,然后调用performSegue,我能够在dataTask之后调用prepare,并允许将我的类变量发送到第二个视图。
帮助我的另一件事是改变我的segue会发生的地方。而不是让它来自按钮,我让它来自viewcontroller,并在单击按钮时执行该segue并从服务器返回并设置我的数据。
感谢大家的帮助,它帮助我理解了这个话题!