繁体   English   中英

UITableViewController在模拟器中显示白色空白屏幕

[英]UITableViewController showing white blank screen in simulator

我正在尝试制作一个非常简单的iOS应用程序,该应用程序从一个UITableViewController开始,当您单击每个单元格(孩子们应该以不同的方式学习)时,它将特定数据推送到UIViewController 我在单元格中添加了占位符信息,但是当我运行模拟器时,只会显示一个空白屏幕。 我在下面附上图片和代码。

主故事板

仿真器

class TableViewController: UITableViewController {

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


    @IBAction func backBtn(_ sender: AnyObject) {
        dismiss(animated: true, completion: nil);
    }

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

    override func numberOfSections(in tableView: UITableView) -> Int {
        return 0
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 0
    }

}

class ViewController: UIViewController, UITableViewDelegate {

    @IBOutlet var tableView: UITableView!

    var names = ["Manner 1", "Manner 2", "Manner 3", "Manner 4", "Manner 6", "Manner 7", "Manner 8"]

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 8
    }

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        var cell = self.tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath as IndexPath) as! Manner2Cell

        cell.name.text = names[indexPath.row]

        return cell
    }

}

//Manner2Cell actually refers to the first cell. I know I know bad naming convention.

class Manner2Cell: UITableViewCell {
    @IBOutlet weak var name: UILabel!

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

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

        // Configure the view for the selected state
    }

}

看所有这些,看来我有一些重复的代码。 我觉得这很容易解决,但我无法弄清楚!

您必须将ViewController设置为tableViewdataSource ,并采用UITableViewDataSource协议。

class ViewController: UITableViewDelegate, UITableViewDataSource, ... {
    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.delegate = self // Assigns ViewController as delegate for tableView 
        tableView.dataSource = self
    }

Interface Builder屏幕快照左上角的场景看起来像UITableViewController (大概是您称为TableViewController的类)。

但是您的numberOfSectionsnumberOfRowsInSection都返回零。 这样您将有一个空白的白色屏幕。 坦白说,看起来第一个场景的UITableViewController子类的代码已经放在第二个场景的视图控制器中。


您的第二个场景(快照的右上角)有点令人困惑,因为它看起来也像是UITableViewController ,但看起来根本不是一个表。 我不确定您要在那做什么。 它真的是一个重复出现的表吗?还是只是作为您在第一个场景中选择的单元格的细节? 如果仅是“详细信息”屏幕,则应该是简单的UIViewController而不是UITableViewController

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM