swift - 如何在 RxDataSource 中反射(reflect)新的部分到 UICollectionView?

标签 swift uicollectionview rx-swift viper-architecture rxdatasources

我正在使用 VIPER 架构使用 RxSwift 和 RxDataSource 构建一个 iOS 应用程序。我想在演示者的值发生变化时更改 UICollectionView 的内容(当用户在搜索栏中输入一些字母时,collectionView 应该显示所有以字母开头的用户个人资料),但它不起作用我想要它。

通过尝试 debug() 函数,ViewController 中 presenter.section 的值(保存 CollectionView 的内容)在我输入一些字母后发生了变化搜索栏。但是,collectionView 没有反射(reflect)出变化。 以下是代码的主要部分。

ViewController代码

override func viewDidLoad() {

    super.viewDidLoad()
    self.view.backgroundColor = .white

    self.presenter.section
        .drive(self.searchedFriendsCollectionView.rx.items(dataSource: self.dataSource))
        .disposed(by: self.disposeBag)

    self.searchedFriendsCollectoinView.rx
        .setDelegate(self)
        .disposed(by: self.disposeBag)
}

Presenter代码

init(view: SearchFriendsViewInterface, interactor: 
SearchFriendsInteractorInterface, wireframe: 
SearchFriendsWireframeInterface) {

    self.view = view
    self.interactor = interactor
    self.wireframe = wireframe

    let allUsers = self.interactor.allUsers().asObservable()

    self.view.searchText
        .debounce(0.5)
        .filterNil()
        .distinctUntilChanged()
        .filterEmpty()
        .asObservable()
        .flatMap { text -> Observable<[SearchFriendsSection]> in
            // get all users starting with "text"
            allUsers.mapSections(query: text)
        }
        .bind(to: self.section)
        .disposed(by: self.disposeBag)
} 

extension Observable where E == [User] {

fileprivate func mapSections(query: String) -> Observable<[SearchFriendsSection]> {

    return self.map {
            $0.filter { $0.userDisplayName.hasPrefix(query) || $0.username.hasPrefix(query) }
        }
        .map { users -> [SearchFriendsSection] in

            let items = users.map { user in
                SearchFriendsItem(icon: user.profileImageURL, displayName: user.userDisplayName)
            }
            return [SearchFriendsSection(items: items)]
        }
    }
}

我如何定义dataSource

override init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: Bundle?) {

    self.searchedFriendsCollectoinView = UICollectionView(frame: .init(), collectionViewLayout: self.searchedFriendsCollectionViewFlowLayout)
    let dataSource = RxCollectionViewSectionedReloadDataSource<SearchFriendsSection> (configureCell: {(_, collectionView, indexPath, item) -> UICollectionViewCell in
        collectionView.register(SearchFriendsCell.self, forCellWithReuseIdentifier: "SearchFriendsCell")
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "SearchFriendsCell", for: indexPath) as! SearchFriendsCell
        cell.item = item
        return cell
    })
    self.dataSource = dataSource
    super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil)
}
  • ViewController 有 Presenter 的实例,presenter 有一个名为 section 的实例。此部分 包含用户名以特定字母开头的用户列表。

你能帮帮我吗?如果我有任何不清楚的地方,请在评论中告诉我。

更新:debug()

的输出
2019-02-01 10:22:27.610: values -> subscribed
2019-02-01 10:22:27.611: values -> Event next([])
--after typed in some letters in the searchBar--
2019-02-01 10:22:41.494: values -> Event 
next([AppScreen.SearchFriendsSection(items: 
[AppScreen.SearchFriendsItem(....), 
AppScreen.SearchFriendsItem(....), 
AppScreen.SearchFriendsItem(....)])])

最佳答案

我发现了你的问题。您从未将 Collection View 添加到主视图中。如果 Collection View 没有 super View ,或者它的大小为零,则它不会自行加载。

将这两行放在您的 viewDidLoad 中:

searchedFriendsCollectionView.frame = view.bounds
view.addSubview(searchedFriendsCollectionView)

当你这样做时,你应该将这一行从你的配置闭包移动到 viewDidLoad 中:

searchedFriendsCollectionView.register(SearchFriendsCell.self, forCellWithReuseIdentifier: "SearchFriendsCell")

没有理由在每次系统请求单元格时都调用它。

关于swift - 如何在 RxDataSource 中反射(reflect)新的部分到 UICollectionView?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54424130/

相关文章:

ios - Collection View 编辑菜单未出现

ios - 防止 UITableView 滚动到某个点以下

swift - 在 SwiftUI 中使用 slider 创建音频播放器单元格

ios - 动态 UITableViewCell 不根据内容调整大小

ios - 图像适合 UICollectionView 单元格

ios - 使用 SDWebImageManager 在 UICollectionView 中延迟加载图像

swift - 如何将 RxSwift 与 AlamoFire 和 SwiftyJSON 结合使用?

ios - DispatchQueue.main.async如何存储它的 block

ios - UIButton 的 rx_tap 不通过嵌套订阅发送请求,如何直接转化为网络请求?

swift - 带有 NSData 变量的 Realm 对象,在展开可选值时意外发现 nil