UIViewController内のUITableViewの機能を更新するプルを実装しようとしています。 UITableViewをView Controllerの小さなサブビューにしたいので、UITableViewControllerを使用できません。これは可能だと思いますが、実装を見た人はいますか?
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がスクロールビューを継承している場合、EGOがスクロールビューをパラメーターとして取得する場所です。
それと、いくつかの追加の接続だけが必要です:)
お役に立てれば。