- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在我的 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;
最佳答案
延迟任意时间并不是一个非常干净的解决方案。在我看来,通过加倍到 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()
}
}
}
关于ios - UIAlertController 有时会阻止 UIRefreshControl 隐藏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41534375/
在我的 UIViewController , 我有一个 UITableView作为 subview 之一。我添加我的 UIRefreshControl使用以下代码: // enable "pull t
我在我的 TableView 中使用 UIRefreshControl 来提取新数据。但是当我定义控件时,下面的错误显示。我用谷歌搜索了一段时间,但没有找到任何有用的信息。 我使用 Xcode 版本
我正在尝试将 UIRefreshControl 移动到我的 headerView 之上,或者至少让它与 contentInset 一起使用。有谁知道如何使用它? 在 TableView 中滚动时,我使
我正在尝试在 UIViewController 中实现 UIRefreshControl。我无法使用 UITableViewController,因为 tableView 只是我的 viewContr
我需要创建一个完全自定义的 UIRefresh控制。动画、图像、下拉量等... 我最初的想法是从头开始,使用 UIViewController,向其中添加我自己的 View ,通过访问 UIScrol
我在 iOS 8 下实现 UIRefreshControl 时遇到了一种闪烁。每次我第一次到达 tableView 的顶部时(即应用程序刚刚启动时),我都会看到下面的 gif 中显示的闪烁。这不会发生
因此,我在 Storyboard 中启用了表格 View 的刷新功能,并将此代码放入 viewDidLoad() 中: refreshControl?.addTarget(self, action:
当我慢慢下拉刷新时,它得到的新内容的顺序不正确。 此外,当我拉刷新时它所堆叠的触发器不会给出任何错误,它只是在 3 个单元格下加载新内容。 import UIKit class ViewControl
我想触发refreshControl在tableView从服务器初始化其数据时自动显示,并且我在这个问题上尝试了多种方法 UIRefreshControl - beginRefreshing not
我已以编程方式将 UIRefreshControl 作为 subview 添加到我的 UICollectionView 中。 lazy var refreshControl: UIRefreshCon
我有一个包含用户帖子的表格 View 。每个帖子都有图片、用户名和帖子本身。刷新控件的操作是使用来自 Parse 的数据重新加载表。除了拉动刷新时的极度延迟外,一切都完美无缺。不知道是因为每个单元格里
目前,我有一个正在使用 UIRefreshControl 的应用程序。 不过我遇到了一些问题...... 这是我的代码: - (void)viewDidLoad { [super viewDi
我为 UICollectionView 实现了一个 UIRefreshControl,这样用户可以通过拉动来刷新 UICollectionView 中的内容。我正在 iPad 模拟器上进行测试。 在第
我有一个带有 TableView 和刷新控件的 View Controller 。当我在刷新过程中旋转屏幕时,刷新控制杆。我试图在 viewWillTransition 和 tableview.ref
我有一个 UITableView,它在 UIViewController 的委托(delegate)上添加了一个新项目,插入了行。该行已正确插入。 但是,之后拖动 UITableView 时,UITa
拉动刷新并没有消失。屏幕上只有 3 行可见,使用 print(indexPath.row) 后我可以看到它再次重新加载行 0、1、2,但刷新控件没有消失。 override func viewDidL
我在 UITableViewController 中有一个 UIRefreshControl。有什么方法可以检测用户是否开始向下拖动 View 以刷新内容?我指的不是 beginRefreshing
我的项目仍在使用 Swift 2.3,尚未迁移到 Swift 3。当我使用以下代码下拉 TableView 时,我可以验证在调试区域中可以看到刷新的数据,但它不会反射(reflect)在 TableV
我做了一个UIRefreshControl: refresher = UIRefreshControl() refresher.attributedTitle = NSAttributedString
今天刚开始使用“UIRefreshControl”,发现了一些奇怪的事情。 如果我在 InterfaceBuilder 中创建了 UIRefreshControl,并将其连接起来,我的选择器将永远不会
我是一名优秀的程序员,十分优秀!