【RxSwift系列】RXSwift在UITableView中使用(一)

1、RootViewController

let disposeBag = DisposeBag()
let dataSource = RxTableViewSectionedReloadDataSource<SectionModel<String,RootModel>>()
let viewModel = RootViewModel()

//綁定數據
viewModel.getNewsData().bind(to: tableView.rx.items(dataSource: dataSource))
        .disposed(by: disposeBag)

//設置cell
dataSource.configureCell = {
        _, tableView, indexPath, model in
        let cell = RootTableViewCell(style: .default, reuseIdentifier: "cell")
        //處理返回數據
        cell.model = model
        return cell
    }

//cell點擊事件
tableView.rx.itemSelected.map { indexPath in
        return (indexPath,self.dataSource[indexPath])
    }
    .subscribe(onNext: { indexPath, model in
        self.navigationController?.pushViewController(FirstViewController(), animated: true)
    })
    .disposed(by: disposeBag)

或者用

tableView.rx
        .modelSelected(FirstModel.self)
        .subscribe(onNext: { (model) in
            self.navigationController?.pushViewController(FirstViewController(), animated: true)
        })
        .addDisposableTo(disposeBag)

2、RootViewModel

func getNewsData() -> Observable<[SectionModel<String, RootModel>]> {
    return Observable.create{ (observer) -> Disposable in
        
        let array = [RootModel(name: "111", age: 10),  RootModel(name: "222", age: 20), RootModel(name: "333", age: 30)]

        let section = [SectionModel(model: "", items: array)]
        observer.onNext(section)
        observer.onCompleted()

        return Disposables.create()
    }
}

3、RootModel

struct RootModel {
    let name: String
    let age: Int
}

4、RootTableViewCell

var model: RootModel? {
    didSet {
            nameLabel.text = model.name
            ageLabel.text = model.age
        }
 }

【RxSwift系列】Moya + RXSwift + HandyJSON在UITableView中的使用(二)http://www.lxweimin.com/p/fe36da1267cd
【RxSwift系列】RxSwift下基于MJRefresh實現下拉刷新,上拉加載(三)http://www.lxweimin.com/p/6f14d6a7cb96

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容