2016-09-23 28 views
7

Ten kod umożliwia aktualizację textField przy użyciu datePicker dla Xcode 7, ale kiedy próbuję go zaimplementować w Xcode 8 i Swift 3, aplikacja ulega awarii i zgłasza błąd SIGABRT w pliku AppDelegate.swift. Sprawdziłem wszystkie moje pliki @IB i nie mam żadnych różnych połączeń, które muszą zostać usunięte. Wszelkie wskazówki będą mile widziane.Swift 3 | Xcode 8 update datePicker UItextField

import UIKit 

class ViewController: UIViewController, UITextFieldDelegate { 
    @IBOutlet var eventStartText: UITextField! 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     eventStartText.delegate = self 

     // Do any additional setup after loading the view. 
    } 

    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
     // Dispose of any resources that can be recreated. 
    } 

    // MARK: TextField Delegate 
    func datePickerChanged(sender: UIDatePicker) { 
     let formatter = DateFormatter() 
     formatter.dateStyle = .full 
     eventStartText.text = formatter.string(from: sender.date) 

     print("Try this at home") 
    } 

    func textFieldDidBeginEditing(_ textField: UITextField) { 
     let datePicker = UIDatePicker() 
     textField.inputView = datePicker 
     datePicker.addTarget(self, action: (Selector(("datePickerChanged:"))), for: .valueChanged) 

     print("This Worked") 
    } 

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

    // MARK: Helper Methods 
    func closekeyboard() { 
     self.view.endEditing(true) 
    } 

    // MARK: Touch Events 
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 
     closekeyboard() 
    } 

    /* 
    // MARK: - Navigation 

    // In a storyboard-based application, you will often want to do a little preparation before navigation 
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    // Get the new view controller using segue.destinationViewController. 
    // Pass the selected object to the new view controller. 
    } 
    */ 
} 
+0

Zobacz http://www.raywenderlich.com/10209/my-app-crashed-now-what-part-1, aby dowiedzieć się, jak debugować awarię. Jeśli potrzebujesz pomocy, zaktualizuj swoje pytanie bardziej trafnymi szczegółami dotyczącymi awarii (komunikat o błędzie i wskaż linię, która rzeczywiście powoduje awarię). – rmaddy

Odpowiedz

13

Problem jest ze składnią selector z Swift 3 trzeba podać imię parametru wewnątrz selector, więc zmienić składnię selector tak.

datePicker.addTarget(self, action: #selector(datePickerChanged(sender:)), for: .valueChanged) 
+0

jesteś gwiazdą rocka! Dziękuję bardzo. To załatwiło sprawę. –

+0

Witaj kolego :) –