0

我正在尝试将 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 中显示它

如您所见,我没有使用任何 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
}

在此先感谢您的帮助

4

1 回答 1

1

更好的方法可能是使用闭包/回调,但要解释发生了什么......

有了这条线:

return cell.contentView

您正在返回单元格的视图。单元类中的代码消失了,因为cell此时超出了范围。

尝试返回单元格本身:

return cell

看看你是否有更好的运气。

于 2020-02-28T18:24:16.633 回答