11.动态单元格的创建

1.一种类型cell的动态单元格


  • 设置
    • 在storyoard中将tableView设置为Dynamic Prototypes(默认就是)
    • 拖一个cell(用原来的那个也可以),在cell上拖一个label命名为cell1,并将cell的Identifier命名为cell1(和之后的代码中的一样),如下图:
      这里写图片描述
  • 代码

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{//这里显示是五行的代码未粘贴
static NSString *reuseIdentifier = @"cell1";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:reuseIdentifier];
return cell;
}

  • 运行效果
    这里写图片描述

  • 原理

    在缓存池中没有找到可利用的cell就会去storyboard中检测有没有为identifier为@”cell1”的cell,
    有的话就会按照这个单元格进行创建

  • 2.在storyboard中创建多种自定义cell

    • 原理

      可以在storyboard中的tableview中创建很多cell并布局不同的UI,设置不同的identifier,根据不同的indexPath设置不同的cellID,会创建出不同的cell,因为可能行高不一样,所以在tableView的代理方法中不同行返回不同的高度

    • 布局
      这里写图片描述

    • 代码

      -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
      static NSString *reuseIdentifier = @"cell1";
      static NSString *reuseIdentifier2 = @"cell2";
      UITableViewCell *cell = nil;
      if (indexPath.row % 2 == 0) {
      cell = [tableView dequeueReusableCellWithIdentifier:reuseIdentifier];
      }else{
      cell = [tableView dequeueReusableCellWithIdentifier:reuseIdentifier2];
      }
      return cell;
      }

      -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
      if (indexPath.row % 2 == 0) {
      return 80;
      }else{
      return 160;
      }
      }

    • 效果
      这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`XSSFWorkbook`是Apache POI库中的一个核心组件,它是一个用于处理Excel 2007及以上版本(.xlsx文件)的HSSF的升级版。Apache POI是一个Java API,允许开发者在Java应用程序中读写Microsoft Office格式的文件,包括Word、Excel和PowerPoint。 当你在Java中使用`XSSFWorkbook`进行动态单元格合并时,你可以这样做: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExcelWriter { public void mergeCells(XSSFWorkbook workbook, Sheet sheet, int row, int col1, int col2) { // 创建Row对象 Row rowObj = sheet.createRow(row); // 获取起始列的Cell对象 Cell cell1 = rowObj.createCell(col1); // 获取结束列的Cell对象 Cell cell2 = rowObj.createCell(col2); // 将起始列的Cell设置为合并单元格 cell1.setCellStyle(workbook.createCellStyle()); cell1.getSheetStyle().setAlignment(HorizontalAlignment.CENTER, VerticalAlignment.CENTER); cell1.setCellValue("这是合并区域"); // 设置结束列的Cell与起始列相同,这样就会合并两个单元格 cell2.setCellType(CellType.BLANK); // 使用BLANK类型确保合并 cell2.copyValueFromCell(cell1); } public static void main(String[] args) { try (XSSFWorkbook workbook = new XSSFWorkbook()) { Sheet sheet = workbook.createSheet("Test Sheet"); ExcelWriter excelWriter = new ExcelWriter(); excelWriter.mergeCells(workbook, sheet, 0, 0, 2); // 合并第一行的A列和B列 // 写入到文件 FileOutputStream fileOut = new FileOutputStream("output.xlsx"); workbook.write(fileOut); fileOut.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 在这个例子中,我们创建了一个`XSSFWorkbook`实例,然后创建了一个新的sheet。`mergeCells`方法接收工作簿、sheet、行号和合并的列坐标,将指定范围内的单元格合并,并设置了居中对齐。`main`方法中,我们创建了表单、调用`mergeCells`方法,然后将整个工作簿写入到`output.xlsx`文件中。 相关问题: 1. `XSSFWorkbook`是用来做什么的? 2. 如何在Java中操作Excel的不同单元格样式? 3. POI库除了`XSSFWorkbook`还有哪些主要组件?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值