Swift中的自定义表格视图单元格,没有Storyboard

时间:2014-09-10 16:41:52

标签: ios uitableview swift

我是学习iOS开发和Swift语言的新手,并且一直试图弄清楚如何在不使用Storyboards / Interface Builder的情况下创建自定义UITableViewCell。我希望能够在Swift代码中完成所有工作。到目前为止,我只能找到使用Interface Builder的那些。

我希望能够创建一个可以在任何表视图中实例化的可重用单元。根据我的理解,我应该能够创建一个带有子视图的自定义单元格,可以通过表格视图的传入数据设置数据。正确?

现在,我有一个UINavigationController,其中包含一个嵌入式的子UITableViewController。在其他一些教程之后,我还学习了如何创建一个Struct并为表视图单元格准备测试数据。但这就是我能够得到的。

// My Table View Controller
class InventoryListViewController: MainTableViewController {

    let viewTitle = "Inventory"
    var inventoryItems = [InventoryItem]()

    override func viewDidLoad() {
        super.viewDidLoad()

        self.navigationItem.title = viewTitle.uppercaseString

        self.inventoryItems = [
            InventoryItem(name: "White Bread", expiry: "2014-09-12"),
            InventoryItem(name: "Mushrooms", expiry: "2014-09-15"),
            InventoryItem(name: "Watermelon", expiry: nil),
            InventoryItem(name: "Leftover Thai", expiry: "2014-09-15"),
            InventoryItem(name: "Cheddar Cheese", expiry: "2014-09-12"),
            InventoryItem(name: "Chicken Breasts", expiry: "2014-09-10"),
            InventoryItem(name: "Paprika", expiry: nil),
            InventoryItem(name: "Sour Cream", expiry: nil)
        ]

        // Right now this will fail without tableView:cellForRowAtIndexPath
        self.tableView.reloadData()
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return self.inventoryItems.count
    }

}

// Sub-classed UITableViewController
class MainTableViewController: UITableViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        self.tableView.separatorColor = UIColor.clearColor()
        self.tableView.contentInset = UIEdgeInsetsZero
    }

}

// Data struct for cells
struct InventoryItem {
    let name: String
    let expiry: String?
}

我理解Swift仍然很新,这可能就是为什么我找不到太多资源来讨论这个话题,所以如果有人有任何指示我会非常感谢你的帮助!

1 个答案:

答案 0 :(得分:10)

您可以将以下代码用于没有情节提要的自定义单元格。只需注册class并将其与tableViewController一起使用

//Cell.Swift

import Foundation
import UIKit

class Cell : UITableViewCell{

    //Do whatever you want as exta customization
}

您的控制器viewDidLoad

override func viewDidLoad() {
    super.viewDidLoad()

    // register your class with cell identifier
    self.tableView.registerClass(Cell.self as AnyClass, forCellReuseIdentifier: "Cell")
}


//cellForRowAtIndexPath

  override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        var cell:Cell? = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as? Cell
        if cell == nil {

            cell = Cell(style: UITableViewCellStyle.Default, reuseIdentifier: "Cell")
        }
        //configure your cell custom code
         cell.textLabel?.text = @"Your Label Text"
        return cell!
    }