Uirefreshcontrol for UitableView不仅在iPhone 6中工作



实际上,除iPhone-6以外的所有设备中,此工作都可以。请帮助我解决这个问题。

我的代码是

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

func refresh(_ sender:AnyObject) {
    if self.appDel.isNetworkEnabled
    {
        DispatchQueue.main.async {
            if(self.page < Int(self.total_pages)! )
            {
                self.page = self.page + 1
                self.fetchMessageApiCall()
            }
        }
    }
    else
    {
        self.singletonObj.showAlert("", message: "No Internet")
    }
    self.refreshControl.endRefreshing()
}

可能是您在从API获取数据时应该放置此self.refreshControl.endRefreshing()

只是这样分配刷新控制器:

    let tableViewControler = UITableViewController()
    tableViewControler.tableView = self.tableView
    self.refreshController = UIRefreshControl()
    self.refreshController.tintColor = UIColor(red: 87.0/255.0, green: 53.0/255.0, blue: 129.0/255.0, alpha: 1.0)
    let attributedString = NSAttributedString(string: "Refresh")
    self.refreshController.attributedTitle = attributedString
    self.refreshController.addTarget(self, action:#selector(self.refresh(_:)), forControlEvents: UIControlEvents.ValueChanged)
    tableViewControler.refreshControl = self.refreshController

希望这有帮助

swift 3.0

我在iOS 10及更高版本中遇到了此问题,并使用以下代码

对其进行了解决。
refreshControl = UIRefreshControl()
refreshControl.attributedTitle = NSAttributedString(string: "Pull to refresh")
refreshControl.addTarget(self, action: #selector(refresh(sender:)), for: UIControlEvents.valueChanged)
    if #available(iOS 10.0, *) {
        self.gigListTableView.refreshControl = refreshControl
    } else {
        // Fallback on earlier versions
        self.gigListTableView.addSubview(refreshControl)
    }

最新更新