UIRefreshControl与自定义TableViewCell结合使用

时间:2017-10-15 21:54:27

标签: swift xcode uitableview uirefreshcontrol

我遇到一个奇怪的问题,当style.cssUIRefreshControl和自定义UITableView结合使用时,UITableViewCells会出现故障。如果我使用基本的(在Xcode的检查器面板中设置)它可以正常工作。请参阅GIFs on Imgur

Normal behaving refresh control with cell style set to basic Glitching refresh control with cell style set to custom, containing a simple UILabel

override func viewDidLoad() {
    super.viewDidLoad()

    navigationController?.navigationBar.prefersLargeTitles = true

    refreshControl = UIRefreshControl()
    refreshControl?.addTarget(self, action: #selector(self.refresh), for: .valueChanged)
    tableView.refreshControl = refreshControl

    refresh()
}

@objc func refresh() {
    tableView.reloadData()
    refreshControl?.endRefreshing()
}

override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return 8
}

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell")
    return cell!
}

UITableView和UITableViewCell上的检查器中的设置是默认设置。我在多个项目中遇到了这个问题。上面的代码是一个干净的项目。刷新控件也会在prefersLargeTitles = false时跳转。

如何使用自定义TableViewCell使刷新控件正常运行?

2 个答案:

答案 0 :(得分:1)

如今,避免上述故障的方法是将tableView.reloadData()调用延迟一小段时间:

self.tableView.refreshControl?.endRefreshing()
self.tableView.perform(#selector(self.tableView.reloadData), with: nil, afterDelay: 0.05)

我认为这并不是真正的解决方案,而是更多的黑客手段。

答案 1 :(得分:0)

这就是我在UITableView中使用自定义单元格添加刷新控件的方法。

lazy var refreshControl: UIRefreshControl = {

    let refreshControl = UIRefreshControl()
    refreshControl.addTarget(self, action: #selector(self.refresh(_:)), for: UIControlEvents.valueChanged)
    return refreshControl

}()

func refresh(_ refreshControl: UIRefreshControl) {

    self.tableView.reloadData()
}

override func viewDidLoad() {
    super.viewDidLoad()
    self.tableView.addSubview(refreshControl)
}

当您完成任务时,可能会添加endRefreshing,而不是在refreshControl本身的操作中添加。