如何使用 RxSwift 管理绑定到 TableViewCell 的树状数据模型

How to manage tree like data models bound to TableViewCell with RxSwift

我有一个如下所示的数据模型,

[Car Brand] has [Types] has Year or specific model (string)

例如

BMW > Z4 > 2005
BMW > Z3 > 1999
BMW > Z3 > 2001
Porshe > Carrera > 1999
Audi > TT > 2002

选择后必须更改 yearView backgroundColor。我在 yearView 中添加了一个 tapGesture,然后尝试从 Type Cell

中监听所有 yearViews
var carForType = PublishSubject<SelectedCar>() // in class property
let bv = yearContainer(frame: .zero, withOption: option)
bv.tap.rx.event.asObservable().map({ _ -> Selected in
    return SelectedBet.init(car: nil, type: self.type, year: option)
})
    .bind(to: self.typeForCar)
    .disposed(by: self.disposeBag)

我正在尝试从 TableVC 中获取所有选定的汽车

cell.selectedCars.debug().subscribe(onNext: {
    var car = [=13=]
    pBet.brand = self.viewModel.brand
    print(car)
}).disposed(by: self.disposeBag)

但是在滚动之后它会双重订阅单元格,总的来说我开始认为应该有更好的方法来做到这一点。关于如何简化的意见会很棒,我愿意改变所有结构。

注意:项目正在使用 MVVM 和 RxDataSources 扩展。

感谢 RxSwift 社区,我已经找到了相同的用例。正如 kzaher 所解释的 here,cell 使用的 disposeBags 需要在 cell 的 prepareForReuse 方法中释放。

但我使用了另一种方法,它不需要单元格中的 disposeBag。我将所有 tapEvents 添加到单元格中的一个数组并将其合并到一个 observable,然后在 tableView 中通过将所有单元格 observables 合并到一个当然在合并之前做同样的事情我将 tapObservables 映射到模型中,该模型包含有关所有汽车的信息细节。它变得像责任链模式 [2]

这里是更多详细信息的代码。

在VC中所有的订阅都已完成。

dataSource = RxTableViewSectionedReloadDataSource<MarketsSectionData>(configureCell: { (dataSource, tableView, indexPath, _) in
    guard let cell = tableView.dequeueReusableCell(withIdentifier: cellReuseId, for: indexPath) as? AllCarsCell else {
        return UITableViewCell()
    }

    let market = dataSource.sectionModels[indexPath.section].items[indexPath.row]
    cell.setUpWith(market: market)
    let sel = cell.selectionsForMarket?.map({ car -> SelectedCar in
        var tCar = car
        tCar.brand = self.viewModel.brand
        return tCar
    })
    self.selectionCells.onNext(sel!)
    cell.findSelectedCellAndFill(withId: self.viewModel.currentCar?.id)
    self.viewModel.selection.subscribe(onNext: { car in
        cell.findSelectedCellAndFill(withId: car.option?.id)
    }, onDisposed: {
        print("deque is disposed")
    }).disposed(by: self.disposeBag)

    return cell
})

self.selectionCells.merge().bind(to: self.viewModel.selection).disposed(by: self.disposeBag)

在单元格中,我将所有视图连接到同一个可观察对象中

self.selectionsForMarket = Observable.from(tapActions).merge()

并且视图是无状态的,只有 tapGesture。