0

我创建了类FooterView:UIView。我用它为我的 TableView 创建 FooterView。但我也想重用这个类来在我的其他 TableViews 中创建 FooterView。当我尝试向 setupElements () 函数添加一个参数以在那里传递所需的 TableView 并根据它更改标签文本时,但初始化程序不允许我这样做。我怎样才能做到这一点?此外,即使我删除了“private”,Swift 也不允许我直接调用 setupElements () 函数。我的代码:

class FooterView: UIView { 
    private var footerLabel: UILabel = {
        ...
    }()

    private func setupElements() {
        addSubview(footerLabel)
        ...
        footerLabel.text = "Table is empty"
    }
    
    override init(frame: CGRect) {
        super.init(frame: frame)
        setupElements()
    }
    
    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}
...
class TableViewController: UIViewController {
   private lazy var footerView = FooterView()
   private var array: [String] = []

   func viewDidLoad() {
      super.viewDidLoad()
      setupTableView()
   }

   private func setupTableView() {
      tableView.register(UINib(nibName: "Cell", bundle: nil), forCellReuseIdentifier: LibraryCell.reuseId)
      if array.count == 0 {
         tableView.tableFooterView = footerView
      }
   }
}

extension TableViewController: UITableViewDelegate, UITableViewDataSource {...}
4

1 回答 1

0

经过大量搜索,我解决了我的问题。我删除了初始化并通过 setupFooterView 函数(对于 vc:UIViewController)创建了一个 FooterView,我将所需的 ViewController 作为参数传递到该函数中。代码如下所示:

class FooterView: UIView {
    private var footerLabel: UILabel = {
        let label = UILabel()
        ...
        return label
    }()

    func setupFooterView(for vc: UIViewController) -> UIView {
        let footerView = UIView()
        footerView.addSubview(footerLabel)
        ...
        if vc is TableViewController {
        footerLabel.text = "..."
        } else if vc is SecondTableViewController {
            footerLabel.text = "..."
        }
        return footerView
    }
}

将 FooterView 添加到我需要的 ViewController 中:

...
private lazy var footerView = FooterView()
...
tableView.tableFooterView = footerView.setupFooterView(for: self)
于 2020-08-21T10:42:44.633 回答