ios - UITableViewCell 在实现为 UITableView 的 FooterView 时无法识别按钮的操作,具有多个页脚视图
问题描述
我正在尝试将 footerView 添加到我的应用程序中的每个单独部分。我已经成功添加了标题,因为它不需要任何按钮,但是当我尝试对我的 footerView 使用相同的实现时,其中必须有一个按钮可以正确识别被点击的部分,它没有不行。我将页眉和页脚视图都添加为 UITableView 中的原型单元格。footerView 是 UITableViewCell 的子类,我在界面生成器中添加了按钮,即使是简单的打印语句也无法运行。
我的 footerView 如何识别我正在按下按钮,以及它如何识别按下它的部分?
import UIKit
class FooterTableViewCell: UITableViewCell {
override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}
var footerDelegate:FooterTableViewCellDelegate?
override func setSelected(_ selected: Bool, animated: Bool) {
super.setSelected(selected, animated: animated)
// Configure the view for the selected state
}
@IBAction func addSetIsPressed(_ sender: UIButton) {
print("Add Set is pressed")
footerDelegate?.didAddSetIsPressed(cell:self)
}
}
protocol FooterTableViewCellDelegate {
func didAddSetIsPressed(cell:FooterTableViewCell)
}
有我的 Footertableviewcell 的实现
如您所见,我没有使用任何 nib 文件或以编程方式添加页脚,我使用了另一个 tableViewCell 并使用它的 view.contents 在 tableview 中显示它
在这里,我在我的 TableView 控制器中实现其余代码
class TableViewController: UITableViewController, ExerciseTableViewCellDelegate, UICollectionViewDelegate, UICollectionViewDataSource, FooterTableViewCellDelegate {
func didAddSetIsPressed(cell: FooterTableViewCell) {
print("Add set is pressed from delegate")
}
override func tableView(_ tableView: UITableView, viewForFooterInSection section: Int) -> UIView? {
let cell = tableView.dequeueReusableCell(withIdentifier: "footerCell") as! FooterTableViewCell
cell.footerDelegate = self
return cell.contentView
}
在此先感谢您的帮助
解决方案
更好的方法可能是使用闭包/回调,但要解释发生了什么......
有了这条线:
return cell.contentView
您正在返回单元格的视图。单元类中的代码消失了,因为cell
此时超出了范围。
尝试返回单元格本身:
return cell
看看你是否有更好的运气。
推荐阅读
- powerbi - 无法计算 power bi 中列总数的百分比
- java - 递归霍夫曼解码函数不退出函数
- docker - 如何访问或将主机文件传递给 Docker Python 脚本
- sql - 如何查找字符在字符串中出现的连续次数
- android - 如何在 facebook graph api 中获取 user_posts 的访问权限
- vue.js - 如何使 Vuex 对列表内对象的属性/属性更改做出反应
- java - 在java中上传内容类型为application / octet-stream的文件?
- mysql - 仅使用 1 个语句从 2 个具有条件的表创建列表
- html - 如何防止 Angular 中的选项卡事件?
- reactjs - 阻止反应路线