我试图在iOS应用程序中使用Storyboard布局中的自定义单元格创建表格视图。
但由于某种原因,没有显示表格单元格。当我尝试设置调试断点时,我发现调试器正在达到此功能
public func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int
但它永远不会达到这个功能 -
public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell
这是我的viewcontroller代码 -
extension NavigationViewController: UITableViewDataSource, UITableViewDelegate, SideMenuControllerDelegate {
public func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return items.count
}
public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "SideMenuTableItem", for: indexPath as IndexPath) as! SideMenuTableItem
cell.setItemData(items[indexPath.row])
return cell
}
public func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func setupTableViews() {
menuTable.register(SideMenuTableItem.self, forCellReuseIdentifier: "SideMenuTableItem")
}
}
class SideMenuTableItem: UITableViewCell {
@IBOutlet weak var menuImage: UIImageView!
@IBOutlet weak var menuLabel: UILabel!
var data: MenuItem?
override func awakeFromNib() {
super.awakeFromNib()
}
func setItemData(_ item: MenuItem) {
data = item
menuLabel.text = data?.title
if data?.icon_res != nil {
menuImage.image = UIImage(named: (data?.icon_res)!)
}
}
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
}
}
我已经在故事板中检查了我已将可重用标识符设置为表原型单元格,并且还将数据源和委托属性连接到tableview
我在创建items数组后调用viewDidLoad()函数中的setupTableViews()方法但是我仍然无法让单元格出现在我的视图中。任何人都可以建议我在这里缺少什么或我的代码有什么问题,或者我怎样才能进一步调试这个问题
import UIKit
import SideMenuSwift
class NavigationViewController: UIViewController {
@IBOutlet weak var navigationContainer: UIView!
@IBOutlet weak var emailButton: UIButton!
@IBOutlet weak var phoneButton: UIButton!
@IBOutlet weak var userAvatar: UIImageView!
@IBOutlet weak var userProfile: UIButton!
@IBOutlet weak var userName: UILabel!
@IBOutlet weak var menuTable: UITableView!
var service: AuthenticationService!
var cdc: CoreDataController!
var items: [MenuItem] = []
var currentUser: User?
override func viewDidLoad() {
super.viewDidLoad()
setupSidebar()
initSidebarData()
setupUserHeader()
setupTableViews()
}
func setupUserHeader() {
if currentUser != nil {
if currentUser?.name != nil {
userName.text = currentUser?.name
} else if currentUser?.role != nil {
userName.text = "urTutors " + (currentUser?.role ?? "")
}
if currentUser?.avatarUrl != nil {
userAvatar.downloaded(from: (currentUser?.avatarUrl)!)
}
}
}
func initSidebarData() {
service = AuthenticationServiceProvider()
cdc = CoreDataController()
items = cdc.getNavigationData()
currentUser = cdc.getUserData()
}
func setupSidebar() {
self.view.backgroundColor = UIColor.hexColor("#fff")
navigationContainer.backgroundColor = UIColor.hexColor("#2a2a2a")
SideMenuController.preferences.basic.statusBarBehavior = .hideOnMenu
SideMenuController.preferences.basic.position = .above
SideMenuController.preferences.basic.direction = .left
SideMenuController.preferences.basic.enablePanGesture = true
SideMenuController.preferences.basic.menuWidth = 275
sideMenuController?.delegate = self
}
static func createViewController() -> NavigationViewController {
let sb = UIStoryboard(name: "StudentHomeModuleStoryboard", bundle: nil)
let vc = sb.instantiateViewController(withIdentifier: "NavigationViewController")
return vc as! NavigationViewController
}
}
--UPDATE--
更新了setupTableLayout函数 -
func setupTableViews() {
let bundle = Bundle(for: type(of: self))
let cellNib = UINib(nibName: "SideMenuTableItem", bundle: bundle)
menuTable.register(cellNib, forCellReuseIdentifier: "SideMenuTableItem")
menuTable.register(SideMenuTableItem.self, forCellReuseIdentifier: "SideMenuTableItem")
menuTable.reloadData()
}
在谈到这个问题之后,我们发现有两个问题。
第一个问题是上面提到的缺少reloadData
电话。这导致cellForRow
不被召唤。添加reloadData
纠正了这个问题,但随后自定义单元类的出口是零,导致setItemData
崩溃。
第二个问题是register(_:forCellReuseIdentifier:)
在代码中调用,但自定义单元格已经设置为Interface Builder UITableView
声明的一部分。再次在自定义类上调用register
重新注册reuseIdentifier
,断开故事板中设置的插座。
删除register
调用并添加reloadData
解决了所有问题。
你永远不会打电话给setupTableViews()
。你的代码应该是这样的:
class NavigationViewController: UIViewController, SideMenuControllerDelegate {
override func viewDidLoad() {
super.viewDidLoad()
setupTableViews()
}
func setupTableViews() {
menuTable.reloadData()
}
}
extension NavigationViewController: UITableViewDataSource, UITableViewDelegate {
public func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return items.count
}
public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "SideMenuTableItem", for: indexPath as IndexPath) as! SideMenuTableItem
cell.setItemData(items[indexPath.row])
return cell
}
public func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
}
您永远不会调用该函数,也不会调用viewDidLoad。这应该有所帮助。此外,你的视图控制器代码的其余部分(这是全部吗?它应该不是!)。
您不需要注册您的单元格,因为您已请求它并确保reloadData()。
希望这可以帮助!