label在cell中 自适应

先在初始化方法中将之创建,并设置numberOfLines = 0

- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
    if (self ) {

 UILabel *tempContent = [[UILabel alloc]initWithFrame:CGRectMake(self.titleLabel.frame.origin.x, CGRectGetMaxY(self.titleLabel.frame),BOUNDS.size.width-self.titleLabel.frame.origin.x-15, 30)];
    tempContent.font = [UIFont systemFontOfSize:14.0f];
    tempContent.textAlignment = NSTextAlignmentLeft;
    tempContent.textColor = CLColor(102, 102, 102);
    tempContent.numberOfLines = 0;
    [self.contentView addSubview:tempContent];
    self.contentLabel = tempContent;

    }
    return self;
}

在添加请求文字的方法中,根据请求到的内容,让其根据内容自适应

- (void)setCellValueWith:(NSDictionary *)param {
 self.contentLabel.frame = CGRectMake(self.titleLabel.frame.origin.x, CGRectGetMaxY(self.titleLabel.frame),BOUNDS.size.width-self.titleLabel.frame.origin.x-15, 0);
        [self.contentLabel sizeToFit];//让内容自适应
    }

控制器界面

//得到内容的自适应高度
-(CGFloat)contentHeightWithSize:(CGFloat)size width:(CGFloat)width string:(NSString *)string{
    //第一个参数:是进行自适应的尺寸  第二个参数:布局格式 第三个参数:字符串的属性列表  第四个忽略
    CGRect rect = [string boundingRectWithSize:CGSizeMake(width, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:size]} context:nil];

    return rect.size.height;

}


- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSDictionary *dic = [_dataSource objectAtIndex:indexPath.row];

   CGFloat contentH = [self contentHeightWithSize:13.0 width:200 string:[dic objectForKey:@"topic"]];

    return 60+contentH;


}

好了,已经可以实现label的自适应啦,是不是很简单

对于 ElementUI 的表格组件,如果你想要实现单元格高度的自适应,可以尝试以下方法: 1. 使用 slot-scope 自定义单元格内容: 在表格组件,可以使用 slot-scope 来自定义单元格内容。你可以在 slot-scope 访问到每个单元格的数据,然后根据数据的长度或内容来动态设置单元格的高度。例如: ```html <el-table :data="tableData"> <el-table-column prop="name" label="姓名"> <template slot-scope="scope"> <div :style="{ height: scope.row.name.length > 10 ? 'auto' : '30px' }"> {{ scope.row.name }} </div> </template> </el-table-column> <!-- 其他列 --> </el-table> ``` 在上述示例,我们通过判断 `scope.row.name` 的长度来决定是否设置 `div` 的高度为 `auto`,如果长度超过 10 就设置为 `auto`,否则设置为固定的 `30px`。 2. 使用 CSS 样式控制单元格高度: 你也可以使用 CSS 来控制单元格的高度。使用 `el-table-column` 的 `className` 属性来添加自定义样式类,然后在这个样式类设置单元格的高度。例如: ```html <style> .custom-cell { height: 30px; } </style> <el-table :data="tableData"> <el-table-column prop="name" label="姓名" :class-name="'custom-cell'"></el-table-column> <!-- 其他列 --> </el-table> ``` 在上述示例,我们在 `el-table-column` 使用 `:class-name` 属性来绑定样式类 `custom-cell`,然后在样式设置了单元格的高度为 `30px`。 以上是两种常用的方法来实现 ElementUI 表格单元格高度的自适应。你可以根据实际需求选择合适的方法进行使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值