问题描述:
开始tableView显示正常,滑动几次后,cell内部的view控件出现重叠,如图所示:

重叠原因:
这是由于,我在代码中,把cell中view控件的添加方法cell.addSubView(view控件)写到了 tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell 方法中。在cell的复用机制下,当滑动tableView时,滑出屏幕的cell会进入复用池,即将显示在屏幕上的cell从复用池中获取cell实例对象,并通过cellForRowAt方法渲染在屏幕上。如此一来,我们一直在获取之前已经添加过各种view组件的cell实例对象,并不断添加其他view组件,由此,造成了重叠现象。
解决方法:
将cell内部view控件的添加,即addSubView(view控件)方法,写到自定义的cell类中,cellForRowAt方法中不再添加view控件只获取使用,相关demo示例请移步至UITableViewCell复用机制的使用步骤 文章查看,这样就能保证view控件不会在cell中被重复添加了。
结果如下:滑动tableView,重叠现象消失,页面正常

博客探讨了UITableView中cell内视图重叠的问题,原因是cell复用机制下,视图添加代码放在了cellForRowAt方法中导致重复添加。解决方案是将视图添加移到自定义cell类中,确保视图只添加一次,从而消除重叠现象。
2096

被折叠的 条评论
为什么被折叠?



