ReusableKit
Cocoa 的通用可重用组件。目前支持 UITableView
和 UICollectionView
。
概述
🤢
之前collectionView.register(UserCell.self, forCellWithReuseIdentifier: "userCell")
collectionView.dequeueReusableCell(withReuseIdentifier: "userCell", for: indexPath) as! UserCell
- 硬编码的字符串标识符可能导致人为错误。
- 应避免强制向下转型。
😊
之后let reusableUserCell = ReusableCell<UserCell>()
collectionView.register(reusableUserCell)
collectionView.dequeue(reusableUserCell) // UserCell
- 使用UUID自动生成一个字符串标识符,并将其存储在结构体中。
- 泛型可以确保脱队单元格的类型在静态上。
示例用法
建议将可重用类型定义为枚举或结构体中的静态常量。
UITableView
// 1. define
enum Reusable {
static let headerView = ReusableCell<SectionHeaderView>()
static let userCell = ReusableCell<UserCell>()
}
// 2. register
tableView.register(Reusable.headerView)
tableView.register(Reusable.userCell)
// 3. dequeue
tableView.dequeue(Reusable.headerView, for: indexPath)
tableView.dequeue(Reusable.userCell, for: indexPath)
UICollectionView
// 1. define
enum Reusable {
static let headerView = ReusableCell<SectionHeaderView>()
static let photoCell = ReusableCell<PhotoCell>()
}
// 2. register
collection.register(Reusable.headerView, kind: .header)
collection.register(Reusable.photoCell)
// 3. dequeue
collection.dequeue(Reusable.headerView, kind: .header, for: indexPath)
collection.dequeue(Reusable.photoCell, for: indexPath)
RxSwift 扩展
ReusableKit 支持RxSwift扩展。
users // Observable<[String]>
.bind(to: collectionView.rx.items(Reusable.userCell)) { i, user, cell in
cell.user = user
}
投稿
欢迎提交 pull request
为了创建 Xcode 项目,请运行
$ swift package generate-xcodeproj
安装
-
针对 iOS 9+ 项目 需要 CocoaPods
pod 'ReusableKit' pod 'ReusableKit/RxSwift' # with RxSwift extension
许可证
ReusableKit 使用 MIT 许可证。更多信息请参阅 LICENSE 文件。