在UITableView中添加多个自定义单元格

时间:2011-04-07 02:01:50

标签: iphone uitableview custom-cell

虽然这是最常问的问题之一,但我找不到一个全面的答案。我需要在UITableView中有自定义单元格。一些包含标签或文本字段,一些包含图像和按钮。我为每种类型的细胞制作了单独的类。我正在使用具有多个部分的GroupStyle表。现在我在cellForIndexPath中添加单元格,其中section为switch-case,if-else为section中的行:

id cell;
switch(indexPath.section) {
    case 0:
           if(indexPath.row==0) {
               CellA *cell = [[[CellA alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:[NSString stringWithFormat:@"Celld%",indexPath.row]] autorelease];
               //configure cell
               return cell;
           }
           else if(indexPath.row==1) {
               CellB *cell = [[[CellB alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:[NSString stringWithFormat:@"Celld%",indexPath.row]] autorelease];
               //configure cell
               return cell;
           }
           break;
    case 1:
           if(indexPath.row==0) {
               CellC *cell = [[[CellC alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:[NSString stringWithFormat:@"Celld%",indexPath.row]] autorelease];
               //configure cell
               return cell;
           }
           break;
    default:
            break;
}
return cell;

我也必须在最后返回单元格,因为由于代码块内部的单元格的定义,单元格变得无法识别。为了解决这个问题,我在顶部声明了id的单元格。但我知道这不是正确的方法。如何解决此声明和访问多种类型单元格的问题?

目前有4-5行适合一个屏幕而不需要滚动。所以,我不是在重复使用细胞。但是在编辑时会挤出更多行。在另一个表中,有更多行可以滚动屏幕。这意味着我必须重复使用细胞。所以,我的问题的第二部分是;如何重用多个自定义单元格?

2 个答案:

答案 0 :(得分:11)

要回答您的第一个问题,您也可以返回nil,因为您没有任何有价值的回报。如果遇到这种情况,将抛出异常;就像现在一样,它可能会在框架代码中的某处给你一个EXC_BAD_ACCESS。

要回答第二个问题,单元格的每个类型都应该有一个唯一的reuseIdentifier。例如,所有CellA都可以具有@“CellA”的reuseIdentifier。然后,您将完全重用它们,就像在所有单元格相同的情况下一样:当您需要CellA调用[tableView dequeueReusableCellWithIdentifier:@"CellA"]时,何时需要CellB调用[tableView dequeueReusableCellWithIdentifier:@"CellB"],依此类推。例如,

    case 0:
        if (indexPath.row == 0) {
            CellA *cell = [tableView dequeueReusableCellWithIdentifier:@"CellA"];
            if (!cell) {
                cell = [[[CellA alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"CellA"] autorelease];
            }
            // configure cell
            return cell;
        }
        else if (indexPath.row == 1) {
            CellB *cell = [tableView dequeueReusableCellWithIdentifier:@"CellB"];
            if (!cell) {
                cell = [[[CellB alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"CellB"] autorelease];
            }
            // configure cell
            return cell;
        }
        break;
    case 1:
        if (indexPath.row == 0) {
            CellC *cell = [tableView dequeueReusableCellWithIdentifier:@"CellC"];
            if (!cell) {
                cell = [[[CellC alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"CellC"] autorelease];
            }
            // configure cell
            return cell;
        }
        break;

答案 1 :(得分:0)

将UITableView添加到UIView.Add自定义单元格,关联自定义单元格类并实现委托-UITableviewDelegate和UITableViewDataSource。

案例1:tableview上的两个自定义单元格

func tableView(tableView:UITableView,cellForRowAtIndexPath indexPath:NSIndexPath) - > UITableViewCell {

  var cell: CustomCell!

  if indexPath.row == 0{
    cell = tableView.dequeueReusableCellWithIdentifier("Cell1ID", forIndexPath: indexPath) as CustomCell
    //set cell2
  }
  if indexPath.row >= 1{
    cell = tableView.dequeueReusableCellWithIdentifier("Cell2ID", forIndexPath: indexPath) as CustomCell
    let cons = aArray[indexPath.row - 1]
    // set cell2 
  }
  return cell
}

案例2:自定义单元格的替代显示(即使用uisegmentcontrol)

var CellIdentifier: String = "Cell1ID"

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
       if (CellIdentifier == "Cell1ID")
    {
let cell = tableView.dequeueReusableCellWithIdentifier(CellIdentifier)! as! FirstTableViewCell

//additional code
return cell

}
else {
let cell = tableView.dequeueReusableCellWithIdentifier(CellIdentifier)! as! SecondTableViewReportsCell

//Additional code

return cell
}
}

案例3:备用自定义单元格(即奇数偶数)

var CellIdentifier: String = "Cell1ID"

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

var cell: CustomCell!

if (indexPath.row % 2 == 0) {

let cell = tableView.dequeueReusableCellWithIdentifier(CellIdentifier)! as! FirstTableViewCell

}
else
{
        let cell = tableView.dequeueReusableCellWithIdentifier(CellIdentifier)! as! SecondTableViewCell
}
return cell
}