ReusableKit 4.0.0

ReusableKit 4.0.0

测试已测试
语言语言 SwiftSwift
许可证 MIT
发布最后发布2023年7月
SPM支持 SPM

Suyeol JeonWooseong Kim 维护。



  • 作者
  • Suyeol Jeon

ReusableKit

Swift CocoaPods Build Status Codecov

Cocoa 的通用可重用组件。目前支持 UITableViewUICollectionView

概述

之前🤢

collectionView.register(UserCell.self, forCellWithReuseIdentifier: "userCell")
collectionView.dequeueReusableCell(withReuseIdentifier: "userCell", for: indexPath) as! UserCell
  1. 硬编码的字符串标识符可能导致人为错误。
  2. 应避免强制向下转型。

之后😊

let reusableUserCell = ReusableCell<UserCell>()
collectionView.register(reusableUserCell)
collectionView.dequeue(reusableUserCell) // UserCell
  1. 使用UUID自动生成一个字符串标识符,并将其存储在结构体中。
  2. 泛型可以确保脱队单元格的类型在静态上。

示例用法

建议将可重用类型定义为枚举或结构体中的静态常量。

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 文件。