我们都知道iOS的UITableView有自带的 左滑动删除的方式,此中方式中,不论是删除数据源,还是删除对应的Cell都是很简单的。可是有时候,产品不是通过滑动删除的,而是点击Cell上的删除图标。本文就是小结一下,商品录入时 UITableViewCell的使用。
Paste_Image.png
# 首先我们知道,如果给Cell的tag,通过 indexPath.row 赋值的话,然后通过获取到要删除的Cell的tag来进行删除操作时,肯定会出错的。
# 删除第二个Cell,成功了,没问题。可是当我们再次删除此时的 第二个(也就是原来的第三个)Cell时,就会出问题了。
# 因为此时被删除的那个Cell的Tag是2,于是我们就移除了 indexPath.row 为2的Cell,可是此时被删除的这个Cell其实在 1的位置,于是我们就删错了。
# 通过上图,我们获得了删除某个Cell 时正确逻辑:
# (1) 首先每个Cell都有一个 CellModel,每个CellModel都有一个值,每次删除一个Cell时,查找 dataArray里面的 CellModel,
# 如果哪个CellModel的值跟 当前Cell的CellModel的值一样的话。记录下它在数组中的 下标 X,移出数组,
# 然后Tb再删除 indexPath.row 为X的Cell就不会有问题了。
# (2) 其实可以这样,每次删除一个Cell时,查找 dataArray里面的 CellModel,哪个CellModel跟 Cell的CellModel一样时,记录下它在数组中的 下标 X,移出数组,
# 然后Tb再删除 indexPath.row 为X的Cell就不会有问题了。
NSIndexPath *cellPath = [NSIndexPath indexPathForRow:(cellTag) inSection:0];
[self.Tb deleteRowsAtIndexPaths:[NSArray arrayWithObjects:cellPath, nil] withRowAnimation:UITableViewRowAnimationAutomatic];
UITableViewCell 在复用的时候,由于没有被销毁,所以里面的全局变量都是存在并保留之前的状态值的,我们在每次使用前都需要对 属性值或者全局变量进行 Model赋值或者 置空(nil)的操作。 # 如果我们不在Cell复用的时候对 属性值或者全局变量进行 Model赋值或者 置空的话,我们下面的操作就会有问题。 # 因为如果当前Cell是没有 storageMode的,可是复用前的Cell有storageMode。我们没有对 当前 存留的storageMode 进行 nil操作, # 下面的逻辑就会有问题了。 if (storageMode) { storageMode.selected = NO; } storageMode =(StorageGoodsMode*)dataDic[@"data"]; storageMode.selected = YES;
如果这些问题都注意了,录入商品的时候关于UITableCell的操作会少走很多弯路。