前言
我们都知道iOS的UITableView有自带的 左滑动删除的方式,此中方式中,不论是删除数据源,还是删除对应的Cell都是很简单的。可是有时候,产品不是通过滑动删除的,而是点击Cell上的删除图标。本文就是小结一下,商品录入时 UITableViewCell的使用。
-
** 关于Cell的高度问题**
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { #关于Cell的高度问题我们可以使用一些第三方的布局框架达到,这里使用的是 CellModel 的属性值记录的方法, #也失为一种方法,使 Cell本身有了修改自己高度的能力。更改完后,刷新指定行即可。 GetMateralCellModel *cellModel =cellModelArray[indexPath.row]; return cellModel.cellHeight; }
关于添加Cell
// 添加商品
- (void)toAddGoods
{
NSIndexPath cellPath = [NSIndexPath indexPathForRow:cellNumebr inSection:0];
# cellNumebr这个值设置为一直增加的值,确保每个 cellNumebr值都是唯一的值。
cellNumebr++;
# 增加CellModel,并把 此时的 cellNumebr赋值给 CellModel。
[self addCellModel];
# 插入一条Cell
[self.Tb insertRowsAtIndexPaths:[NSArray arrayWithObjects:cellPath, nil] withRowAnimation:UITableViewRowAnimationNone];
# 增加动态添加的动画
if (cellNumebr<4) {#小于4个不需要位移(此时还未满屏,不需要自动上移)
return;
}
[UIView animateWithDuration:0.6 delay:0 options:UIViewAnimationOptionCurveEaseInOut animations:^{
[self.Tb setContentOffset:CGPointMake(0, Scale_Y((160(cellNumebr-3))+70))];
} completion:^(BOOL finished) {}];
}关于删除Cell
# 首先我们知道,如果给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];
-
提交所有录入的数据
遍历 dataArray里面的 CellModel,获取到每个Cell的数据,提交上传即可。**无法通过cellForRowAtIndexPath 的方法获取到所有的Cell的录入数据,因为这个方法只能获取到,出现在屏幕中的Cell,对于那些未出现的Cell里的数据是无法获取的(也没有,或因为复用导致之前的数据而不复存在) **
需要注意的事
UITableViewCell 在复用的时候,由于没有被销毁,所以里面的全局变量都是存在并保留之前的状态值的,我们在每次使用前都需要对 属性值或者全局变量进行 Model赋值或者 置空(nil)的操作。
# 如果我们不在Cell复用的时候对 属性值或者全局变量进行 Model赋值或者 置空的话,我们下面的操作就会有问题。
# 因为如果当前Cell是没有 storageMode的,可是复用前的Cell有storageMode。我们没有对 当前 存留的storageMode 进行 nil操作,
# 下面的逻辑就会有问题了。
if (storageMode) {
storageMode.selected = NO;
}
storageMode =(StorageGoodsMode*)dataDic[@"data"];
storageMode.selected = YES;
小结
如果这些问题都注意了,录入商品的时候关于UITableCell的操作会少走很多弯路。