我是学习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仍然很新,这可能就是为什么我找不到太多资源来讨论这个话题,所以如果有人有任何指示我会非常感谢你的帮助!
答案 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!
}