[英]How to realize UIPickerView with RXSwift
items.bindTo(tableView.rx.items(cellIdentifier: "cellIdentifier", cellType: AttentionTableViewCell.self)){(row,dic,cell) in
cell.configueCell(with: dic)
}.addDisposableTo(dispose)
Maybe you just have to update your RxSwift library version. 也许您只需要更新RxSwift库版本即可。 It looks like pretty much the same as UI{Table|Collection}View rx bindings. 它看起来与UI {Table | Collection} View rx绑定几乎相同。 Supposing you have a data source like: 假设您有一个数据源,例如:
let items: Observable<[String]> = Observable.of(["Row1", "Row2", "Row3"])
To populate your UIPickerView: 要填充您的UIPickerView:
items.bind(to: yourPickerView.rx.itemTitles) { (row, element) in
return element
}
.disposed(by: disposeBag)
To handle selected items: 处理选定的项目:
yourPickerView.rx.itemSelected
.subscribe { (event) in
switch event {
case .next(let selected):
print("You selected #\(selected.row)")
default:
break
}
}
.disposed(by: disposeBag)
Swift4 example Swift4示例
Observable.just(["Yes", "No", "Maybe"])
.bind(to: picker.rx.itemTitles) { _, item in
return "\(item)"
}
.disposed(by: disposeBag)
picker.rx.itemSelected
.subscribe(onNext: { (row, value) in
NSLog("selected: \(row)")
})
.disposed(by: disposeBag)
Provided data source of your picker looks like this: 选择器提供的数据源如下所示:
let pickerDataSource: [[String]] = [ ["asdadadad", "sffgddfg"],
["sfsdasgag", "sdfasdfasfsf", "sdsfgagagaggs"] ]
you could implement 'binding' in this way: 您可以通过以下方式实现“绑定”:
pickerView.rx.itemSelected.subscribe(onNext: {[weak self](row,component) in
guard let s = self else { return }
s.label.text = s.pickerDataSource[component][row]
}).disposed(by: disposeBag)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.