UITableViewCell publi c функция не выполняется - PullRequest
0 голосов
/ 21 июня 2020
var list = [String]()
@IBOutlet weak var TableView: UITableView!

override func viewDidLoad() {
    self.title = "Routines"
    TableView.delegate = self
    TableView.dataSource = self
    super.viewDidLoad()
}
//refresh view when going back to this viewcontroller
override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)
    print("Test Worked")
    TableView.reloadData()
}
//generating rows
public func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int{
    return (list.count)
}

//returning text in UITableViewCell
public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell{
        let cell = UITableViewCell(style:
            UITableViewCell.CellStyle.default, reuseIdentifier:
        "prototype1")
        print("printed")
        cell.textLabel?.text = list[indexPath.row]
        return cell
}
//deleting rows
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath)
    {
        if editingStyle == UITableViewCell.EditingStyle.delete{
            deleteAllData("ToDo")
            self.list.remove(at: indexPath.row)
            TableView.reloadData()
    }
    
}
@IBAction func didAdd() {
    
    let storyboard = UIStoryboard(name: "Main", bundle: nil)
    let vc = storyboard.instantiateViewController(identifier: "addRoutinePage")as! addRoutinePage
    self.navigationController?.pushViewController(vc, animated: true)

}

//function to get data from core data
func getData()
{
    let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
    let request = NSFetchRequest<NSFetchRequestResult>(entityName: "ToDo")
    request.returnsObjectsAsFaults = false
    do{
        //fetching data from coredata
        let result = try context.fetch(request)
        for data in result as! [NSManagedObject]
        {
            //appending the list from the value in coredata (attribute) or entity
            self.list.append(data.value(forKey: "title")as! String)
            print("append success")
        }
    }catch {
        print("failed")
    }
}

Что не так с моим кодом? Кажется, все работает, кроме UITableViewCell, команда печати, которую я ввел, чтобы проверить, выполняется ли функция, даже не сработала. Я попробовал TableView.reloadData (), но он все еще не работал. Логически, если проблема связана с функцией publi c, источником данных или делегатом, он даже не будет генерировать никаких строк, но они будут созданы. Я тоже попытался изменить размер высоты ячейки, но это все равно не сработает. Пожалуйста, помогите!

1 Ответ

0 голосов
/ 21 июня 2020

В коде есть несколько ошибок:

  1. Вам необходимо перезагрузить, когда загрузка данных из CoreData будет завершена.
func getData() {
    let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
    let request = NSFetchRequest<NSFetchRequestResult>(entityName: "ToDo")
    request.returnsObjectsAsFaults = false
    do {
        let result = try context.fetch(request)
        for data in result as! [NSManagedObject] {
            self.list.append(data.value(forKey: "title")as! String)
        }
        self.TableView.reloadData()
    } catch {
        print(error)
    }
}
Также не забудьте вызвать функцию getData.
override func viewDidLoad() {
    super.viewDidLoad()
    title = "Routines"
    TableView.delegate = self
    TableView.dataSource = self
    getData()
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...