swift - UITableViewCell复用机制的使用步骤

前言:UITableViewCell的复用机制是指,只创建一定数量的cell,然后将它们储存起来,在滑动屏幕的过程中,循环重复使用这些cell。这样做既避免了储存cell时对内存的消耗,又避免了频繁创建和销毁cell时对性能的影响。

实现方法:自定义tableViewCell类、注册cell复用池、调用复用池中的cell

步骤一:创建Cell.swift文件,让该类继承TableViewCell,代码如下:

import UIKit

// MARK: - 自定义TableViewCell,以便使用“复用”特性。
class Cell: UITableViewCell {
    // 在cell中自定义控件Label,根据个人需求创建,这里只做示例
    var titleLabel = UILabel()
    
    // 初始化自定义控件
    override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) {
        super.init(style: .value1, reuseIdentifier: nil)
        
        // 设置label控件
        self.titleLabel.frame = CGRect(x: 20, y: 15, width: 60, height: 20)
        self.titleLabel.backgroundColor = .green
        self.contentView.addSubview(self.titleLabel)
    }
    
    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

这里一定要注意,cell内部view控件添加方法addSubView()务必在自定义Cell类中实现,否则将会在滑动屏幕的过程中出现重叠现象!!!具体重叠现象和原因可移步至 UITableViewCell复用机制下,内部view控件出现重叠的问题​​​​​​​ 文章查看。

步骤二:自定义创建TableViewController.swift文件让该类继承UITableViewController类。并使用方法:“self.tableView.register(自定义cell类, forCellReuseIdentifier: 标识符字符串) 注册tableViewCell复用池。代码如下:

import UIKit

class TableViewController: UITableViewController {
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // (重要!!!)注册tableViewCell复用池,使用“cellReusing”对自定义Cell进行标识
        self.tableView.register(Cell.self, forCellReuseIdentifier: "cellReusing")
    }
    
    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)

        // 页面显示之前,刷新表格数据
        self.tableView.reloadData()
    }
    
}

步骤三:在上面创建的TableViewController.swift文件中,实现tabeleview的代理方法,完成表格的显示。使用方法:“self.tableView.dequeueReusableCell(withIdentifier: 标识符字符串), for: indexPath) as! 自定义cell的类名 ”获取cell(如有,直接从队列中取出;如没有,会自动创建),这里注意标绿的两个参数与注册复用池时设置的保持一致。代码如下:

// MARK: - 实现tabeleview的代理方法
extension TableViewController1 {
    // 设置section的数量
    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    // 设置每个section的行数
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 15
    }
    
    // 设置每一行需要展示的数据
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        // (重要!!!)从cell复用池中取出cell进行使用,并强制转换为对应的类型
        let cell = self.tableView.dequeueReusableCell(withIdentifier: "cellReusing", for: indexPath) as! Cell
        
        // 对cell的内部view控件进行处理
        cell.titleLabel.text = String(indexPath.row)
        
        return cell
    }
    
    // 设置行高
    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 200
    }
}

结果:tableView控件添加成功

最后,我们可以在滑动tableView的过程中,在控制台打印一下页面展示cell的地址信息进行验证:

以图中标注出的几个cell信息为例,可以看到,相同的cell确实被重复使用了。 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值