如何解决如何防止xib单元覆盖静态单元
所以我创建了一个 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 举报,一经查实,本站将立刻删除。