質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.48%

'Could not load NIB in bundle: 'NSBundle<----.app>(loaded)' with name 'memoCell'

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 3,021

score 100

質問したいこと

いつもお世話になっております。
現在、Todoリストのようなアプリを作っており、そこで以下のエラーが出てきてしまいます。

reason: 'Could not load NIB in bundle: 'NSBundle <.app> (loaded)' with name 'memoCell''

コード

//一番最初の画面
import UIKit

final class ViewController: UIViewController {

    // MARK: IBOutlet

    @IBOutlet weak var tableView: UITableView!

    // MARK: Properties

    private let model = UserDefaultsModel()
    private var dataSource: [Memo] = [Memo]() {
        didSet {
            tableView.reloadData()
        }
    }

    // MARK: Lifecycle

    static func instance() -> ViewController {
        let vc = UIStoryboard(name: "ViewController", bundle: nil).instantiateInitialViewController() as! ViewController
        return vc
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        configureUI()
        configureTableView()
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        loadMemos()
    }

    // MARK: IBAction

    @objc
    private func onTapAddButton(_ sender: UIBarButtonItem) {
        let vc = AddViewController.instance()
        navigationController?.pushViewController(vc, animated: true)
    }
}

// MARK: - Configure

extension ViewController {

    private func configureUI() {
        navigationItem.title = "メモ一覧"
        navigationItem.rightBarButtonItem = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(onTapAddButton(_:)))
    }

    private func configureTableView() {
        tableView.delegate = self
        tableView.dataSource = self
//        print("tableView.delegate = self") OK
        tableView.tableFooterView = UIView()
//        print("tableView.FooterView = UIView()") OK
        tableView.rowHeight = TableViewCell.rowHeight
//        print("tableView.rowHeight") OK
        tableView.register(TableViewCell.nib, forCellReuseIdentifier: TableViewCell.reuseIdentifier)
//        print("tableview.regidter(TableViewCell.nib, forCellReuseIdentifier: TableViewCell.reuseIdentifier)") OK
    }
}

// MARK: - Model

extension ViewController {

    private func loadMemos() {
        guard let memos = model.loadMemos() else { return }
        self.dataSource = memos
//        print("loadMemos") OK
    }
}

// MARK: - TableView dataSource, delegate

extension ViewController: UITableViewDataSource, UITableViewDelegate {

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
//        print(dataSource.count) 011
        return dataSource.count
    }
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        tableView.register(TableViewCell.self, forCellReuseIdentifier: NSStringFromClass(TableViewCell.self))
//        print("tableView.register(TableViewCell.self, forCellReuseIdentifier: NSStringFromClass(TableViewCell.self))") OK
        let cell = tableView.dequeueReusableCell(withIdentifier: TableViewCell.reuseIdentifier, for: indexPath) as! TableViewCell
//        print("let cell = tableView.dequeueReusableCell(withIdentifier: TableViewCell.reuseIdentifier, for: indexPath) as! TableViewCell") No
        let memo = dataSource[indexPath.row]
        cell.setupCell(title: memo.title, content: memo.content)
        return cell
    }

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        tableView.deselectRow(at: indexPath, animated: true)

        let memo = dataSource[indexPath.row]
        let vc = DetailViewController.instance(memo)
        // セルの選択を解除
        tableView.deselectRow(at: indexPath, animated: true)

        // 別の画面に遷移
        performSegue(withIdentifier: "toDetail", sender: nil)
        navigationController?.pushViewController(vc, animated: true)
    }
}
//カスタムセル
import UIKit

class TableViewCell: UITableViewCell {

    // MARK: IBOutlet

    @IBOutlet private weak var titleLabel: UILabel!
    @IBOutlet private weak var contentLabel: UILabel!

    // MARK: Static properties

    static let reuseIdentifier = "memoCell"
    static let rowHeight: CGFloat = 60
    static var nib: UINib {
        return UINib(nibName: "memoCell", bundle: nil)
    }

    // MARK: Overrides

    override func awakeFromNib() {
        super.awakeFromNib()
    }

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)
    }

    // MARK: Setup

    func setupCell(title: String, content: String) {
        titleLabel.text = title
        contentLabel.text = content
    }
}

やってみたこと

print()で調べてみたところ、ViewControllerの

let cell = tableView.dequeueReusableCell(withIdentifier: TableViewCell.reuseIdentifier, for: indexPath) as! TableViewCell


の部分でエラーが起きていると判明しました。
しかしながら、どのようにエラーを直せばいいのかわかりません。

エラー

reason: 'Could not load NIB in bundle: 'NSBundle <.app> (loaded)' with name 'memoCell''


よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

reason: 'Could not load NIB in bundle: 'NSBundle <.app> (loaded)' with name 'memoCell''

こちらのエラーはUINibをインスタンス化する時に
momoCellという名前のファイルを読みこむことができなかったため発生しています。

問題となっているのは以下の部分です。

class TableViewCell: UITableViewCell {

    // MARK: Static properties

    static let reuseIdentifier = "memoCell"
    static let rowHeight: CGFloat = 60

    // この部分
    static var nib: UINib {
        return UINib(nibName: "memoCell", bundle: nil)
    }
}

クラス名がTableViewCellとなっているので、
xibファイルもTableViewCell.xibみたいな名前で作られていると思うので以下のようにすればセルをTableViewにきちんと登録できるはずです。

class TableViewCell: UITableViewCell {

    // MARK: Static properties

    // ついでに reuse identifier も変えた方がいいと思います.
    static let reuseIdentifier = "TableViewCell"
    static let rowHeight: CGFloat = 60

    // 正しいファイルを読み込むように引数nibNameに渡す文字列を変更.
    static var nib: UINib {
        return UINib(nibName: "TableViewCell", bundle: nil)
    }
}

もしxibファイルの名前が違うなら、その名前で上記の部分を書き換えてあげれば問題ないはずです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/03/05 19:49

    回答ありがとうございます。
    直りました!
    しかし、新しいエラーが発生してしまったので、新しく質問を建てさせていただくので、
    そちらの方もよろしければ回答よろしくお願いします。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.48%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る