0

Table View Controller を配置し、IB の Navigation Controller に埋め込みます。その後、次のコードで WalletsTableViewController クラスを作成します。

class WalletsTableViewController: UITableViewController {

    private var wallets = [Wallet]()

    override func viewDidLoad() {
        super.viewDidLoad()
        fetchWallets()
    }

    private func fetchWallets(){
        let managedObjectContext = AppDelegate.managedContext
        let fetchRequest: NSFetchRequest<Wallet> = Wallet.fetchRequest()
        do {
            wallets = try managedObjectContext.fetch(fetchRequest)
        } catch {
            print(error.localizedDescription)
        }
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection: Int) -> Int {
        return wallets.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "WalletCell", for: indexPath) 
        let wallet = wallets[indexPath.row]
        cell.textLabel?.text = wallet.name
        return cell
    }
}

私は永続的なアプリケーションを実装しているため、fetchWallets() メソッドがあり、うまく機能します。データをコンソールに出力できますが、tableView は要素を表示したくありません。さらに、実装された tableView() メソッドは呼び出されません。この問題を解決するにはどうすればよいですか?

編集: tableView.reloadData() は役に立ちませんでした

EDIT2:これが私のストーリーボードです: 絵コンテ

4

3 に答える 3

0

上記のコメントで提案されているように、次のことを試してください。

    private func fetchWallets(){
    let managedObjectContext = AppDelegate.managedContext
    let fetchRequest: NSFetchRequest<Wallet> = Wallet.fetchRequest()
    do {
        wallets = try managedObjectContext.fetch(fetchRequest)
        self.tableView.reloadData()
    } catch {
        print(error.localizedDescription)
    }
}
于 2017-11-28T13:16:17.293 に答える
0

私の悪い... 自動実装された関数を削除しませんでした。これで私の問題は解決しました。

于 2017-11-28T16:02:15.547 に答える