我在我的tableview上使用UIRefreshControl
来更新项目。最后,我显示UIAlertController
以通知用户更新已完成,以及更新了多少项。非常简单,它适用于一件事。如果我连续多次刷新,有时即使解除警报后刷新控制也不会被解除。我需要向上滑动桌子才能让它消失。
这是我使用的代码,所有UI内容都在主线程上完成:
if(refreshControl.refreshing) {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[self refreshItems];
dispatch_async(dispatch_get_main_queue(), ^{
[refreshControl endRefreshing];
[self.tableView reload];
[self showUpdateInfo];
});
});
}
知道可能导致这种情况的原因吗?
编辑:这是我在代码中创建刷新控件的方法(在viewDidLoad
中):
UIRefreshControl *refreshControl = [[UIRefreshControl alloc] init];
refreshControl.attributedTitle = [[NSAttributedString alloc] initWithString: @"Checking for updates…"];
[refreshControl addTarget: self
action: @selector(refreshOutdatedItems)
forControlEvents: UIControlEventValueChanged];
self.refreshControl = refreshControl;
答案 0 :(得分:7)
延迟任意时间并不是一个非常干净的解决方案。在我看来,通过计算一倍到1000万来实现延迟也是一个黑客攻击。
我最终做的是类似于这个伪Swift:
let alert = UIAlertController(...)
present(alert, animated: true) {
refreshControl.endRefreshing()
}
它会将调用延迟到endRefreshing(),直到出现警报。
我使用Swift 3和PromiseKit的实际代码看起来更像是这样:
@IBAction func onRefresh() {
Repository.getNewData().then { data in
self.data = data
self.tableView.reloadData()
}.recover { error in
// Return a promise to make sure endRefreshing isn't called until the alert is presented.
return self.presentErrorAlert(message: "Some user-friendly message")
}.always {
self.refreshControl?.endRefreshing()
}
}
private func presentErrorAlert(message: String) -> Promise<Void> {
return Promise<Void> { fulfill, _ in
let alert = UIAlertController(title: "Error", message: message, preferredStyle: .alert)
alert.addAction(UIAlertAction(title: "OK", style: .default, handler: nil))
self.present(alert, animated: true) {
fulfill()
}
}
}
答案 1 :(得分:3)
那些对我有用:
refreshControl.endRefreshing()
tableView.setContentOffset(CGPoint.zero, animated: true)
-- show alert than --
答案 2 :(得分:2)
只需重置表格视图的内容偏移量:
- (void)endRefreshControl {
[self.tableView setContentOffset:CGPointMake(0, -self.refreshControl.bounds.size.height) animated:YES];
[self.refreshControl endRefreshing];
}
任务完成后,请致电[self endRefreshControl];
而不是[self.refreshControl endRefreshing];
答案 3 :(得分:0)
这似乎是Xcode中的一个错误。甚至约翰莱文的解决方案有时似乎也会出现在Xcode 9.2中。
它并不完全是您正在寻找的,但它是一种解决方法:不要使用UIAlertController。只需将UIAlertController中的文本放入UIRefreshControl,就像这样:
refreshControl?.attributedTitle = NSAttributedString(string: "Pull to reload all reminders", attributes: [NSAttributedStringKey.foregroundColor: UIColor(red: 255.0/255.0, green: 182.0/255.0, blue: 8.0/255.0, alpha: 1.0)])
答案 4 :(得分:-3)
我认为它确实与tableView在呈现UIAlertController之前不会向上滚动。我试图设置showUpdateInfo方法的延迟,这似乎有效。我想当用户只拉一次它需要半秒钟来显示UIAlertController检查是否有帮助。 这是我的代码
- (void)refreshOutdatedItems
{
NSLog(@"refresh");
if (self.refreshControl.refreshing) {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
for (double i = 0 ; i < 100000000; i++){
};
dispatch_async(dispatch_get_main_queue(), ^{
[self.refreshControl endRefreshing];
[self performSelector:@selector(showUpdateInfo) withObject:nil afterDelay:0.5];
});
});
}
}
如果有帮助,请告诉我。