带有RxCocoa的UITableView无法正确观察contentOffset属性

时间:2019-07-14 10:15:26

标签: ios swift uitableview rx-swift rx-cocoa

使用RxCocoa观察UITableView的contentOffset属性时遇到问题。

我已经尝试过RxCocoa属性:

view.tableView.rx.contentOffset
                .mapAt(\.y)
                .subscribe(onNext: { print($0) })

在控制台中,我一次看到(0,0)

我尝试用RxCocoa中的代码替换它:

ControlProperty(
                values: BehaviorSubject<CGPoint>(value: RxScrollViewDelegateProxy.proxy(for: view.tableView).scrollView?.contentOffset ?? CGPoint.zero),
                valueSink: Binder(view.tableView) { scrollView, contentOffset in
                        scrollView.contentOffset = contentOffset
                    }
                )
                .subscribe(onNext: { print("myOffset", $0) })

得到相同的结果: myOffset(0,0)一次,什么都没有。

我试图观察其他财产,却一无所获:

view.tableView.rx.didScroll
                .subscribe(onNext: { print(view.tableView.contentOffset) })

但是。我尝试添加可观察间隔:

Observable<Int>.interval(1, scheduler: MainScheduler.instance)
                .subscribe(onNext: { _ in print(view.tableView.contentOffset) })

每秒钟我都有不同的观点:(0,0),(0,38),(0,64)

我正在使用: RxCocoa(5.0.0); RxSwift(5.0.0)

1 个答案:

答案 0 :(得分:0)

您尚未向我们显示实际上导致问题的代码。请注意,以下内容可以完美运行:

final class ViewController: UIViewController {
    private var tableView: UITableView!
    private let disposeBag = DisposeBag()

    override func loadView() {
        super.loadView()
        tableView = UITableView(frame: view.bounds)
        tableView.register(UITableViewCell.self, forCellReuseIdentifier: "Cell")
        view.addSubview(tableView)
    }

    override func viewWillLayoutSubviews() {
        super.viewWillLayoutSubviews()
        tableView.frame = view.bounds
    }

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.rx.contentOffset
            .map { $0.y }
            .bind(onNext: { print($0) })
            .disposed(by: disposeBag)

        Observable.just(Array.init(repeating: "Item", count: 35))
            .bind(to: tableView.rx.items) { (tableView, row, element) in
                let cell = tableView.dequeueReusableCell(withIdentifier: "Cell")!
                cell.textLabel?.text = "\(element) @ row \(row)"
                return cell
            }
            .disposed(by: disposeBag)
    }
}