使用 swift 中的委托将字符串从一个 viewcontroller 发送到另一个
Sending a string from one viewcontroller to another using delegate in swift
我试图在 PopupViewController 中单击按钮,用字符串 "svimmelhed, ".
填充 DagbogsindlaegViewController 中的文本字段
我在 运行 运行代码时没有收到任何错误,但是当我 运行 应用程序模拟并在 [=24] 中按 "ButtonPressSvimmelhed" 时文本不存在=] 弹出视图控制器。
有好心的陌生人可以帮助我并告诉我我做错了什么吗?
代码如下:
import UIKit
import EventKit
class DagbogsindlaegViewController: UIViewController{
@IBAction func BackToSVC(_ sender: Any){
self.performSegue(withIdentifier: "BackToSVCSegue", sender: self)
}
@IBAction func ToCalenderButtonPress(_ sender: Any) {
self.performSegue(withIdentifier: "ToCalenderSegue", sender: self)
}
override func viewDidLoad() {
super.viewDidLoad()
TitleTextField.delegate = self
DescriptionTextField.delegate = self
// Do any additional setup after loading the view.
}
@IBOutlet weak var TitleTextField: UITextField!
@IBOutlet weak var DescriptionTextField: UITextField!
func addEventToCalendar(title: String, description: String?, startDate: Date, endDate: Date, completion: ((_ success: Bool, _ error: NSError?) -> Void)? = nil) {
let eventStore = EKEventStore()
eventStore.requestAccess(to: .event, completion: { (granted, error) in
if (granted) && (error == nil) {
let event = EKEvent(eventStore: eventStore)
event.title = title
event.startDate = startDate
event.endDate = endDate
event.notes = description
event.calendar = eventStore.defaultCalendarForNewEvents
do {
try eventStore.save(event, span: .thisEvent)
} catch let e as NSError {
completion?(false, e)
return
}
completion?(true, nil)
} else {
completion?(false, error as NSError?)
}
})
}
@IBAction func ButtonPressGemDagbog(_ sender: Any) {
addEventToCalendar(title: "\(String(describing: TitleTextField.text!))", description: "\(String(describing: DescriptionTextField.text!))", startDate: NSDate() as Date, endDate: NSDate() as Date)
}
@IBAction func ButtonPressPopupMenu(_ sender: Any) {
let popOverVC = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "PopupViewControllerID") as! PopupViewController
self.addChild(popOverVC)
popOverVC.view.frame = self.view.frame
self.view.addSubview(popOverVC.view)
popOverVC.didMove(toParent: self)
}
}
extension DagbogsindlaegViewController : UITextFieldDelegate {
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
}
extension DagbogsindlaegViewController : TextFraPopupDelegate {
func Symptomer(Svimmelhed: String) {
TitleTextField.text = Svimmelhed
}
}
另一个视图控制器:
import UIKit
protocol TextFraPopupDelegate{
func Symptomer(Svimmelhed: String)
}
class PopupViewController: UIViewController {
var symptomDelegate: TextFraPopupDelegate?
override func viewDidLoad() {
super.viewDidLoad()
self.showAnimate()
self.view.backgroundColor = UIColor.black.withAlphaComponent(0.8)
// Do any additional setup after loading the view.
}
@IBAction func ButtonPressBackToDagbogsindlaeg(_ sender: Any) {
self.removeAnimate()
//self.view.removeFromSuperview()
}
func showAnimate()
{
self.view.transform = CGAffineTransform(scaleX: 1.3, y: 1.3)
self.view.alpha = 0.0;
UIView.animate(withDuration: 0.25, animations: {
self.view.alpha = 1.0
self.view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0)
});
}
func removeAnimate()
{
UIView.animate(withDuration: 0.25, animations: {
self.view.transform = CGAffineTransform(scaleX: 1.3, y: 1.3)
self.view.alpha = 0.0;
}, completion:{(finished : Bool) in
if (finished)
{
self.view.removeFromSuperview()
}
});
}
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) {
if sender.isSelected {
sender.isSelected = false
} else {
sender.isSelected = true
}
symptomDelegate?.Symptomer(Svimmelhed: "Svimmelhed, ")
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
}
}
如评论中所述,委托未设置。
但是在 Swift 中,有一种更方便的方法可以将字符串传回呈现视图控制器,即回调闭包。你摆脱了协议和设置委托的职责
- 删除
protocol TextFraPopupDelegate{
func Symptomer(Svimmelhed: String)
}
在PopupViewController
中替换
var symptomDelegate: TextFraPopupDelegate?
和
var callback : ((String) -> Void)?
和
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) {
if sender.isSelected {
sender.isSelected = false
} else {
sender.isSelected = true
}
symptomDelegate?.Symptomer(Svimmelhed: "Svimmelhed, ")
}
和
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) {
sender.isSelected.toggle()
callback?("Svimmelhed, ")
}
在DagbogsindlaegViewController
中在ButtonPressPopupMenu
中添加闭包
@IBAction func ButtonPressPopupMenu(_ sender: Any) {
let popOverVC = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "PopupViewControllerID") as! PopupViewController
self.addChild(popOverVC)
popOverVC.view.frame = self.view.frame
popOverVC.callback = { string in
self.TitleTextField.text = string
}
self.view.addSubview(popOverVC.view)
popOverVC.didMove(toParent: self)
}
最后删除
extension DagbogsindlaegViewController : TextFraPopupDelegate {
func Symptomer(Svimmelhed: String) {
TitleTextField.text = Svimmelhed
}
}
备注:
语法 (_ success: Bool, _ error: NSError?) -> Void)?
已过时。由于 Swift 3 参数标签消失了,这就足够了:(Bool, NSError?) -> Void)?
不要在 Swift 中使用 NS...
类 如果有原生的对应物,例如 Date
请遵守命名规则,以小写字母开头的变量和函数/方法命名。
语法"\(String(describing: TitleTextField.text!))"
是双重冗余。您从字符串中的字符串创建字符串。将其替换为 TitleTextField.text!
我试图在 PopupViewController 中单击按钮,用字符串 "svimmelhed, ".
填充 DagbogsindlaegViewController 中的文本字段我在 运行 运行代码时没有收到任何错误,但是当我 运行 应用程序模拟并在 [=24] 中按 "ButtonPressSvimmelhed" 时文本不存在=] 弹出视图控制器。 有好心的陌生人可以帮助我并告诉我我做错了什么吗?
代码如下:
import UIKit
import EventKit
class DagbogsindlaegViewController: UIViewController{
@IBAction func BackToSVC(_ sender: Any){
self.performSegue(withIdentifier: "BackToSVCSegue", sender: self)
}
@IBAction func ToCalenderButtonPress(_ sender: Any) {
self.performSegue(withIdentifier: "ToCalenderSegue", sender: self)
}
override func viewDidLoad() {
super.viewDidLoad()
TitleTextField.delegate = self
DescriptionTextField.delegate = self
// Do any additional setup after loading the view.
}
@IBOutlet weak var TitleTextField: UITextField!
@IBOutlet weak var DescriptionTextField: UITextField!
func addEventToCalendar(title: String, description: String?, startDate: Date, endDate: Date, completion: ((_ success: Bool, _ error: NSError?) -> Void)? = nil) {
let eventStore = EKEventStore()
eventStore.requestAccess(to: .event, completion: { (granted, error) in
if (granted) && (error == nil) {
let event = EKEvent(eventStore: eventStore)
event.title = title
event.startDate = startDate
event.endDate = endDate
event.notes = description
event.calendar = eventStore.defaultCalendarForNewEvents
do {
try eventStore.save(event, span: .thisEvent)
} catch let e as NSError {
completion?(false, e)
return
}
completion?(true, nil)
} else {
completion?(false, error as NSError?)
}
})
}
@IBAction func ButtonPressGemDagbog(_ sender: Any) {
addEventToCalendar(title: "\(String(describing: TitleTextField.text!))", description: "\(String(describing: DescriptionTextField.text!))", startDate: NSDate() as Date, endDate: NSDate() as Date)
}
@IBAction func ButtonPressPopupMenu(_ sender: Any) {
let popOverVC = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "PopupViewControllerID") as! PopupViewController
self.addChild(popOverVC)
popOverVC.view.frame = self.view.frame
self.view.addSubview(popOverVC.view)
popOverVC.didMove(toParent: self)
}
}
extension DagbogsindlaegViewController : UITextFieldDelegate {
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
}
extension DagbogsindlaegViewController : TextFraPopupDelegate {
func Symptomer(Svimmelhed: String) {
TitleTextField.text = Svimmelhed
}
}
另一个视图控制器:
import UIKit
protocol TextFraPopupDelegate{
func Symptomer(Svimmelhed: String)
}
class PopupViewController: UIViewController {
var symptomDelegate: TextFraPopupDelegate?
override func viewDidLoad() {
super.viewDidLoad()
self.showAnimate()
self.view.backgroundColor = UIColor.black.withAlphaComponent(0.8)
// Do any additional setup after loading the view.
}
@IBAction func ButtonPressBackToDagbogsindlaeg(_ sender: Any) {
self.removeAnimate()
//self.view.removeFromSuperview()
}
func showAnimate()
{
self.view.transform = CGAffineTransform(scaleX: 1.3, y: 1.3)
self.view.alpha = 0.0;
UIView.animate(withDuration: 0.25, animations: {
self.view.alpha = 1.0
self.view.transform = CGAffineTransform(scaleX: 1.0, y: 1.0)
});
}
func removeAnimate()
{
UIView.animate(withDuration: 0.25, animations: {
self.view.transform = CGAffineTransform(scaleX: 1.3, y: 1.3)
self.view.alpha = 0.0;
}, completion:{(finished : Bool) in
if (finished)
{
self.view.removeFromSuperview()
}
});
}
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) {
if sender.isSelected {
sender.isSelected = false
} else {
sender.isSelected = true
}
symptomDelegate?.Symptomer(Svimmelhed: "Svimmelhed, ")
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
}
}
如评论中所述,委托未设置。
但是在 Swift 中,有一种更方便的方法可以将字符串传回呈现视图控制器,即回调闭包。你摆脱了协议和设置委托的职责
- 删除
protocol TextFraPopupDelegate{
func Symptomer(Svimmelhed: String)
}
在
PopupViewController
中替换var symptomDelegate: TextFraPopupDelegate?
和
var callback : ((String) -> Void)?
和
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) { if sender.isSelected { sender.isSelected = false } else { sender.isSelected = true } symptomDelegate?.Symptomer(Svimmelhed: "Svimmelhed, ") }
和
@IBAction func ButtonPressSvimmelhed(_ sender: UIButton) { sender.isSelected.toggle() callback?("Svimmelhed, ") }
在
DagbogsindlaegViewController
中在ButtonPressPopupMenu
中添加闭包@IBAction func ButtonPressPopupMenu(_ sender: Any) { let popOverVC = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "PopupViewControllerID") as! PopupViewController self.addChild(popOverVC) popOverVC.view.frame = self.view.frame popOverVC.callback = { string in self.TitleTextField.text = string } self.view.addSubview(popOverVC.view) popOverVC.didMove(toParent: self) }
最后删除
extension DagbogsindlaegViewController : TextFraPopupDelegate {
func Symptomer(Svimmelhed: String) {
TitleTextField.text = Svimmelhed
}
}
备注:
语法
(_ success: Bool, _ error: NSError?) -> Void)?
已过时。由于 Swift 3 参数标签消失了,这就足够了:(Bool, NSError?) -> Void)?
不要在 Swift 中使用
NS...
类 如果有原生的对应物,例如Date
请遵守命名规则,以小写字母开头的变量和函数/方法命名。
语法
"\(String(describing: TitleTextField.text!))"
是双重冗余。您从字符串中的字符串创建字符串。将其替换为TitleTextField.text!