问题描述
所以我创建了一个 xib 单元格,并成功地将它实现到我的 tableVC 中。我还在 tableVC 的另一部分创建了一个静态单元格,但是当我运行应用程序时,xib 单元格覆盖了静态单元格,并且只有当我单击 xib 单元格时才显示静态单元格。我读了 10 个关于这个重复问题的其他问题,但它们都是完全不同的情况,有些是在目标 C 中,所以我试图复制不同的答案,但没有一个奏效。
这是加载时的tableVC ....
按钮重复两次,当我点击它时,单元格显示为灰色。
当我单击 xib 单元格本身时,该单元格变为白色,就像我希望它在 vc 加载时最初的样子一样。
我将添加我的 viewDidLoad()
、cellForRowAt()
、heightForRowAt()
方法。有两个部分,每个部分也有一个单元格。此外,320 单元格高度是 xib 单元格的准确高度。
override func viewDidLoad() {
super.viewDidLoad()
tableView.separatorStyle = .none
tableView.register(UINib.init(nibName: Constants.CellDetails.DeleteAccountCell,bundle: nil),forCellReuseIdentifier: Constants.CellDetails.DeleteAccountCellIdentifier)
tableView.register(UITableViewCell.self,forCellReuseIdentifier: "deleteCell")
view.backgroundColor = .lightGray
title = "Delete My Account"
navigationItem.hidesBackButton = true
navigationItem.leftBarButtonItem = UIBarButtonItem(image: UIImage(systemName: "arrow.backward"),style: .done,target: self,action: #selector(backTapped))
navigationItem.leftBarButtonItem?.tintColor = .white
navigationController?.navigationBar.largeTitleTextAttributes = [NSAttributedString.Key.foregroundColor: UIColor.white,NSAttributedString.Key.font: UIFont(name: Constants.AppFonts.menuTitleFont,size: 35)]
}
cellForRowAt()
...
override func tableView(_ tableView: UITableView,cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: Constants.CellDetails.DeleteAccountCellIdentifier,for: indexPath) as! DeleteAccountCell
let deleteCell = tableView.dequeueReusableCell(withIdentifier: "deleteCell")
if indexPath.section == 0 && indexPath.row == 0 {
return cell
} else {
deleteCell?.backgroundColor = .white
deleteCell?.textLabel?.text = "Delete My Account"
deleteCell?.textLabel?.textAlignment = .center
return deleteCell!
}
}
最后是 heightForRowAt()
方法。
override func tableView(_ tableView: UITableView,heightForRowAt indexPath: IndexPath) -> CGFloat {
if indexPath.row == 0 && indexPath.section == 0{
return 320
} else {
return 50
}
}
如果有人能指出错误和建议,将不胜感激。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)