2017-04-19 27 views
0

表の行セルを編集しようとしています。私は別のtableViewControllerを初期のtableViewControllerから表示されたイベントに触れるときに現在のイベントを表示/編集するように設定しました。イベントを編集して保存を押すたびに、最初にイベントを表示しているメインのviewControllerに戻りますが、編集したイベントは表示されません。元のイベントを表示し続けます。表の行セルを変更する3

class EditEventsTableViewController: UITableViewController { 

@IBOutlet weak var txtEditTitle: UITextField! 

var index:Int! 

var eventsArray = [Event]() 

var editedTitle: String! 

override func viewDidLoad() { 
    super.viewDidLoad() 

    txtEditTitle.text = eventsArray[index!].title 
} 


func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { 
    if indexPath.section == 0 && indexPath.row == 0 { 
     txtEditTitle.becomeFirstResponder() 
    } 
    tableView.deselectRow(at: indexPath as IndexPath, animated: true) 
} 

override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    if segue.identifier == "save" { 
     editedTitle = txtEditTitle.text 
    } 
} 
} 

包みあなたたちはより良い必要がある私は私のデータを編集するのはここ

class EventsTable: UIViewController, UITableViewDataSource, UITableViewDelegate { 

var tableData = ViewController() 

@IBOutlet weak var table: UITableView! 


@IBAction func saveToMainViewController (change:UIStoryboardSegue) { 

    let editViewController = change.source as! EditEventsTableViewController 

    let index = editViewController.index 

    let titleString = editViewController.editedTitle 

    tableData.eventsArray[index!].title = titleString 

    table.reloadData() 
} 


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
    // #warning Incomplete implementation, return the number of rows 
    return tableData.eventsArray.count 
} 


func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 

    let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! CustomeCell 

    cell.eventTitle.text = tableData.eventsArray[indexPath.row].title 

    cell.eventLocation.text = tableData.eventsArray[indexPath.row].location 

    cell.eventDateAndTime.text = tableData.eventsArray[indexPath.row].date 

    return cell 
} 

//function to delete cell and saves it 
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) { 
    if editingStyle == .delete { 
     tableData.eventsArray.remove(at: indexPath.row) 

     table.reloadData() 

     let savedEvents = NSKeyedArchiver.archivedData(withRootObject: tableData.eventsArray) 

     UserDefaults.standard.set(savedEvents, forKey: "savedEvents") 

     UserDefaults.standard.synchronize() 
    } 
} 

override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    if segue.identifier == "edit" { 

     var path = table.indexPathForSelectedRow 

     let detailViewController = segue.destination as! EditEventsTableViewController 

     detailViewController.index = path?.row 
     detailViewController.eventsArray = tableData.eventsArray 
    } 

} 

が他のtableViewControllerである:ここでは

は私が私のイベントを表示しています私のメインのtableViewファイルの一部でありますプロジェクトを見て、 download linkプロジェクト

+0

クラスでなければならない特定の 'Event'をEdit Controllerに渡し、オブジェクト内で直接変更を行うことをお勧めします。その後、戻ってテーブルビューをリロードします。参照セマンティクスのために、変更は持続します。 – vadian

答えて

0

おそらくEditEventsTableViewControllerあなたは見逃したテーブルビューreloadi ng?

override func viewDidLoad() { 
    super.viewDidLoad() 

    tableView.reloadData() 
    txtEditTitle.text = eventsArray[index!].title 
} 

EditEventsTableViewControllerのデータはどこにありますか。それはストーリーボードで設計された静的なテーブルビューですか?

関連する問題