我正在尝试在UIViewController中的UITableView中实现拉动刷新功能。我不能使用 UITableViewController,因为我希望 UITableView 是视图控制器中较小的子视图,上面有一些其他的东西。我认为这是可能的,但是有人看到它的实现吗?
将刷新控件直接添加到UITableView
而不使用UITableViewController
:
override func viewDidLoad() {
super.viewDidLoad()
let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: #selector(refresh(_:)), for: .valueChanged)
if #available(iOS 10.0, *) {
tableView.refreshControl = refreshControl
} else {
tableView.backgroundView = refreshControl
}
}
@objc func refresh(_ refreshControl: UIRefreshControl) {
// Do your job, when done:
refreshControl.endRefreshing()
}
Objective-C :
这是实现拉取以刷新表视图的方法。与集合视图的情况相同。只需将表视图分配替换为集合视图即可。
UITableView *tableViewDemo = [[UITableView alloc]init];
tableViewDemo.frame = CGRectMake(0,0,self.view.frame.size.width,self.view.frame.size.height);
tableViewDemo.dataSource = self;
tableViewDemo.delegate = self;
[self.view addSubView: tableViewDemo];
UIRefreshControl *refreshController = [[UIRefreshControl alloc] init];
[refreshController addTarget:self action:@selector(handleRefresh:) forControlEvents:UIControlEventValueChanged];
[tableViewDemo addSubview:refreshController];
#pragma mark - Handle Refresh Method
-(void)handleRefresh : (id)sender
{
NSLog (@"Pull To Refresh Method Called");
[refreshController endRefreshing];
}
@berik的这个解决方案工作正常,但UIController显示在UITableViewController的顶部。修复它的方法是进行此更改:
override func viewDidLoad() {
let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: "refresh:", forControlEvents: .ValueChanged)
tableView.backgroundView = refreshControl // <- THIS!!!
}
func refresh(refreshControl: UIRefreshControl) {
// Do your job, when done:
refreshControl.endRefreshing()
}
我已经用UIViewController和一个简单的表视图实现了EGORefreshTableHeaderView,诀窍是在一个EGO将滚动视图作为参数的地方,如果你看表视图本身继承自滚动视图。
它只需要这个和一些额外的连接:)
希望这有帮助。
似乎如果你在viewController的loadView方法中创建UIRefreshControl,一切正常。UIRefreshControl 的行为符合预期。在 iOS 7.1 和 iOS 8.2 上进行测试
我最终使用了ODRefreshControl。它不需要像上面tableView.backgroundView = refreshControl
那样的任何黑客,工作方式几乎相同,并提供更好看的用户界面。