Reusable
Reusable是一个在swift下使用的开源库。利用protocol extension结合泛型提供了一个优雅的方案来dequeueReusableCell。使用 根据类型获取cell让你的cell声明Reusable或NibReusable协议
//如果cell定义在xib中,声明NibReusableclass
MyCustomCell: UITableViewCell, NibReusable { }
//如果cell是基于纯代码的,声明Reusableclass
MyCustomCell: UITableViewCell, Reusable { }
接着在tableview中register
tableView.register(UINib.init(nibName: "MyCustomCell", bundle: nil), forCellWithReuseIdentifier: "MyCustomCell")
在collectionView中使用Reusable register
collectionView.register(cellType: SubscribeCell.self)
collectionView.register(supplementaryViewType: SubscribeHeader.self, ofKind: UICollectionView.elementKindSectionHeader)
collectionView.register(supplementaryViewType: SubscribeFooter.self, ofKind: UICollectionView.elementKindSectionFooter)
在collectionView中没有使用Reusable register Header和Footer
//返回的是xib
collectionView.register(UINib(nibName: "SubscribeHeader", bundle: nil), forSupplementaryViewOfKind: UICollectionView.elementKindSectionHeader, withReuseIdentifier: "SubscribeHeader")
collectionView.register(UINib(nibName: "SubscribeFooter", bundle: nil), forSupplementaryViewOfKind: UICollectionView.elementKindSectionFooter, withReuseIdentifier: "SubscribeFooter")
粗暴的直接获取cell就可以啦:
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell:myCell = tableView.dequeueReusableCell(for: indexPath, cellType: MyCustomCell.self)
if dataList.count > indexPath.row{
cell.model = dataList[indexPath.row]
}
return cell
}
是的。你没有看错,这样就能获取到这个类型的reuse cell,不需要传入reuseIdentifiers,不需要UITableViewCell类型强转。根据类型获取xib中的UIView对象 UIView对象声明NibLoadable协议。
对比
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "UITableViewCell") ?? UITableViewCell.init(style: .subtitle, reuseIdentifier: "UITableViewCell")
cell.textLabel?.font = UIFont.init(name: "", size: 14.0)
cell.textLabel?.text = self.dataArray[indexPath.row]
return cell
}
网友评论