TableView не появляется в моем контейнере - PullRequest
0 голосов
/ 08 мая 2018

Я абсолютно новичок в разработке яблок. В настоящее время я создаю iPad, используя концепцию мастер-деталей. В моем подробном представлении у меня есть несколько основных элементов (таких как текстовые поля и т. Д.), А также контейнер, и внутри этого контейнера есть tableView. Я следую этому руководству: https://www.youtube.com/watch?v=AaCfwqzH9SQ

Моя проблема в том, что мои фиктивные данные не отображаются в виде таблицы. Это просто пустая таблица. Но он распечатывает мое лог-сообщение, которое я включил в метод viewDidLoad.

Расположение контейнера со встроенным переходом от контейнера к представлению таблицы

Это мой класс, связанный с табличным представлением:

import UIKit

class TaskTableViewController: UITableViewController {

var Array = [String]()

override func viewDidLoad() {
    super.viewDidLoad()
    print("IN THE TASKBAR")
    Array = ["ffff","ddd","sss"]

    // Uncomment the following line to preserve selection between presentations
    // self.clearsSelectionOnViewWillAppear = false

    // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
     self.navigationItem.rightBarButtonItem = self.editButtonItem
}

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

// MARK: - Table view data source

override func numberOfSections(in tableView: UITableView) -> Int {
    // #warning Incomplete implementation, return the number of sections
    return 0
}

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


override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) 


    //THIS IS WHER YOU'D PROGRAM YOUR TASK THINGS
    cell.textLabel?.text = Array[indexPath.row]

    // Configure the cell...


    return cell
}


/*
// Override to support conditional editing of the table view.
override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
    // Return false if you do not want the specified item to be editable.
    return true
}
*/

/*
// Override to support editing the table view.
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
        // Delete the row from the data source
        tableView.deleteRows(at: [indexPath], with: .fade)
    } else if editingStyle == .insert {
        // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
    }    
}
*/

/*
// Override to support rearranging the table view.
override func tableView(_ tableView: UITableView, moveRowAt fromIndexPath: IndexPath, to: IndexPath) {

}
*/

/*
// Override to support conditional rearranging of the table view.
override func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
    // Return false if you do not want the item to be re-orderable.
    return true
}
*/

/*
// MARK: - Navigation

// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
    // Get the new view controller using segue.destinationViewController.
    // Pass the selected object to the new view controller.
}
*/

}

1 Ответ

0 голосов
/ 08 мая 2018

numberOfSections не должен возвращаться zero. Для отображения некоторой ячейки в вашем tableView должен быть доступен хотя бы один раздел.

override func numberOfSections(in tableView: UITableView) -> Int {
    // #warning Incomplete implementation, return the number of sections
    return 1
}

Также вызовите ваш tableView на reloadData после того, как вы вставите что-то в ваш Array

override func viewDidLoad() {
    super.viewDidLoad()
    print("IN THE TASKBAR")
    Array = ["ffff","ddd","sss"]
    self.tableView.reloadData()
    // Uncomment the following line to preserve selection between presentations
    // self.clearsSelectionOnViewWillAppear = false

    // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
     self.navigationItem.rightBarButtonItem = self.editButtonItem
}

Предположим, этот метод будет выполняться при нажатии кнопки.

func didClickedOnEditButton(button: UIButton){
    //First add string into your array
    Array.append("This is the newly inserted String")
    //Then ask your TableView to reload Everything
    tableView.reloadDate()
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...