2017-02-21 7 views
0

XCode 8でSwift 3を習得しようとしています。そして、チュートリアルに続き、独自のアプリケーションを構築しています。日付とカテゴリ。データをコアデータに保存する

今は、データをコアデータに保存するのが苦労しています。その上で、私はUITextfieldに完全なデータスタイルを表示したいが、それを短いデータスタイルとしてコアデータに保存する。

誰にでも解決策がありますか?そして、私はn00bです、私はすべての正しい専門用語にないことに注意してください。だから私が変えなければならないことを私に見せてください。私は今でもさまざまなことを学んでいます...

私がするべきことは、文字列を書式設定する関数を作ることです。コアデータ(エンティティ 'MyEvents'の属性 'dateOfEvent'は 'date'に設定されています)を呼び出し、それをdatePickerChanged関数から呼び出して、常に更新します。

これまで私が見つけたのは、私が見つけた別のチュートリアルのミックスです。

import UIKit 

class addEventViewController: UIViewController, UITextFieldDelegate, UIPickerViewDataSource, UIPickerViewDelegate { 
    @IBOutlet weak var addEventNameInput: UITextField! 
    @IBOutlet weak var addEventDateInput: UITextField! 
    @IBOutlet weak var addEventCategoryInput: UITextField! 

    var addEventCategories = ["Født", "Startede børnehave", "Startede uddannelse", "Startede job", "Flyttede hjemmefra", "Startede romantisk forhold", "Startede forhold"] 
    var categoryPicker = UIPickerView() 

    let datePicker = UIDatePicker() 

    func textFieldDidBeginEditing(_ textField: UITextField) { 
     addEventDateInput.inputView = datePicker 
     datePicker.datePickerMode = .date 
     datePicker.addTarget(self, action: #selector(datePickerChanged), for: .valueChanged) 
    } 

    func datePickerChanged(sender: UIDatePicker) { 
     let formatter = DateFormatter() 
     formatter.dateStyle = .full 
     formatter.timeStyle = .none 

     addEventDateInput.text = formatter.string(from: sender.date) 
    } 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     addEventNameInput.delegate = self 
     addEventDateInput.delegate = self 

     categoryPicker.delegate = self 
     categoryPicker.dataSource = self 
     addEventCategoryInput.inputView = categoryPicker 
    } 

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

    // returns the number of 'columns' to display. 
    func numberOfComponents(in pickerView: UIPickerView) -> Int { 
     return 1 
    } 

    // returns the # of rows in each component.. 
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 
     return addEventCategories.count 
    } 

    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 
     addEventCategoryInput.text = addEventCategories[row] 
    } 

    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 
     return addEventCategories[row] 
    } 

    @IBAction func addEventButtonPressed(_ sender: Any) { 
     if addEventNameInput.text == "" { 
     } else { 
      let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext 

      let newevent = MyEvents(context: context) 
      newevent.nameOfevent = addEventNameInput.text! 
      newevent.categoryOfevent = addEventCategoryInput.text! 

      // Save data to coredata 
      (UIApplication.shared.delegate as! AppDelegate).saveContext() 

      // Pop back to events list 
      navigationController!.popViewController(animated: true) 
     } 
    } 
} 
+0

したがって、 'MyEvents'の一部として' dateOfEvent'という名前のNSManagedObjectがあります。 'new event.dateOfEvent = datePicker.date'と言ってあなたのdatePickerに現在の日付が何であっても値を設定できるはずです – Pierce

+0

ありがとう、Pierce! それは日付を保存しますが、時間も節約します。そして、私は日付だけを望みます:-) – Polle

+0

@Polle「日付のみ」はありません。実際の日付をデータベースに保存し、日付フォーマッタを使用してそれらの値をユーザに表示します。 – jrturton

答えて

0

データベースに日付として保存する必要があります。日付オブジェクトは特定の瞬間を表しているため、「時間のない日付」はありません。

ユーザーに興味のある日付の部分のみを表示するには、日付フォーマッタを使用します。表示形式とデータ格納を混同しないでください。

管理対象オブジェクトのタイプ属性はDateで、ピッカーのdateプロパティに設定するだけです。

関連する問題