gpt4 book ai didi

ios - 将变量结果从一个 View Controller 传递到另一个非 View Controller swift 文件

转载 作者:行者123 更新时间:2023-11-28 15:10:42 24 4
gpt4 key购买 nike

我正在尝试制作一个 iOS 应用程序,它从文本字段中获取用户名,将其转换为字符串并将其传递给另一个我称为 HomeModel.swift 的文件。此文件不是 ViewController,但我需要将该变量名添加到 URL。

目前,我的应用设置了一个初始 View Controller ,该 View Controller 具有一个用于用户名的文本字段和一个登录按钮。当我单击登录按钮时,它获取文本字段条目并将其转换为一个字符串,然后我将其用于转换为下一个 ViewController 上的标签。我的问题是获取用户名变量(我曾经将其转换为标签)并将其传递给非 ViewController swift 文件,这样我就可以用它做一些“幕后”工作。

任何帮助将不胜感激,因为我花了数小时试图找到答案但人手不足。

这是我的初始 ViewController

import UIKit

class Home: UIViewController, UITextFieldDelegate {

@IBOutlet var TextField: UITextField!
@IBOutlet var PasswordField: UITextField!
@IBOutlet var LoginBtn: UIButton!

override func viewDidLoad() {
super.viewDidLoad()

self.TextField.delegate = self
self.PasswordField.delegate = self

func checkField(sender: Any?) {
if (TextField.text?.isEmpty)! || (PasswordField.text?.isEmpty)!
{
LoginBtn.isEnabled = false

}
else
{
LoginBtn.isEnabled = true
}
}
}

//Hide keyboard when touched outisde keyboard
override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
self.view.endEditing(true)
}

func textFieldShouldReturn(_ textField: UITextField) -> Bool {
PasswordField.resignFirstResponder()
return (true)
}

override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()

}

override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
let DestViewController : ViewTwo = segue.destination as! ViewTwo

DestViewController.PasswordText = PasswordField.text!
DestViewController.LabelText = TextField.text!
}

}

这是 HomeModel.swift 文件

import Foundation

protocol HomeModelProtocol: class {
func itemsDownloaded(items: NSArray)
}

class HomeModel: NSObject, URLSessionDataDelegate {

//properties

weak var delegate: HomeModelProtocol!

func viewDidLoad() {

}

func downloadItems() {

let myusername = //Variable from initial controller here

let urlPath = "http://urlhere.com/index.php?username="+myusername //this is where the list of users are

let url: URL = URL(string: urlPath)!
let defaultSession = Foundation.URLSession(configuration: URLSessionConfiguration.default)
let task = defaultSession.dataTask(with: url) { (data, response, error) in

if error != nil {
print("Failed to download data")
}
else {
print("Contact List Data Downloaded")
self.parseJSON(data!)
}
}
task.resume()
}

func parseJSON(_ data:Data) {
var jsonResult = NSArray()
print (jsonResult)

do {
jsonResult = try JSONSerialization.jsonObject(with: data, options:JSONSerialization.ReadingOptions.allowFragments) as! NSArray

}
catch let error as NSError {
print(error)
}

var jsonElement = NSDictionary()
let locations = NSMutableArray()

for i in 0 ..< jsonResult.count
{
jsonElement = jsonResult[i] as! NSDictionary

let location = LocationModel()

//the following insures none of the JsonElement values are nil through optional binding
if let name = jsonElement["name"] as? String,
let phone = jsonElement["phone"] as? String
{
location.name = name
location.phone = phone
}

locations.add(location)
}

DispatchQueue.main.async(execute: { () -> Void in

self.delegate.itemsDownloaded(items: locations)

})
}
}

最佳答案

一般来说,根据您的描述,这只是在您拥有的 View Controller 之间传递对象。假设有:

class LoginData {
var username: String?
}

现在你的第一个 View Controller 似乎是你的入口点,所以它是创建它的那个,例如在按下“下一步”按钮时。然后这个对象应该被传递给新的 View Controller :

@IBAction onNextPressed() {
let loginData = LoginData() // Create object
loginData.username = self.textField.text // Set data to it

let nextController = UIStoryboard(...) as! NextViewController // Generate new view controller
nextController.loginData = loginData // Assign login data
navigationController.push(... nextController ...) // Show controller
}

那么下一个 View Controller 应该使用这个对象:

class NextViewController: UIViewController {
var loginData: LoginData?

override func viewDidLoad() {
super.viewDidLoad()
self.label.text = loginData?.username
}

...

但在某些情况下(这似乎是您的情况),全局保存数据可能是有意义的。为此,您只需要一个静态变量。对于您的情况,我建议您创建一个新对象 User

class User {
static var current: User?

var loginData: LoginData?
}

现在 User 只包含登录数据,但还有一个占位符来添加当前用户的实例,可以在应用程序内随时使用。

现在对于这种情况,第一个 View Controller 不需要将数据传递给下一个 View Controller ,而是设置当前用户:

@IBAction onNextPressed() {
let loginData = LoginData() // Create object
loginData.username = self.textField.text // Set data to it

let newUser = User() // Create a new user
newUser.loginData = loginData // Assign login data to it
User.current = newUser // Set current user

let nextController = UIStoryboard(...) // Generate new view controller
navigationController.push(... nextController ...) // Show controller
}

而且新的 View Controller 不需要对登录数据的引用:

class NextViewController: UIViewController {

override func viewDidLoad() {
super.viewDidLoad()
self.label.text = User.current?.loginData?.username
}

...

当您需要在整个应用程序中使用这些数据时,这非常有用,正如您提到的一些 url 您现在可以在任何地方调用 User.current?.serviceURL 如果您实现:

extension User {
var serviceURL: URL? {
guard let username = username else {
return nil
}
return URL(string: "https://some.pat/\(username)/resource_name")
}
}

我希望这能澄清一些关于在 Swift 中传递数据的事情。

关于ios - 将变量结果从一个 View Controller 传递到另一个非 View Controller swift 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47689856/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com