python tableview 自适应_iOS tableviewcell 自适应高度

tableviewcell的自适应高度一般是根据里面label的长度高度自适应。下面介绍两个最简单的方法

1.在使用xib和纯代码结合的时候,可能会遇到就是cell的自定义时,可能就会有遇到在同一个UITableView中可能有两种状态共存的情况,而且cell的高度有固定高度,也存在根据label字数自适应高度的时候就需要分开判断了。

苹果有一个自带的属性设置就是

self.tableView.rowheight =  UITableViewAutomaticDimension;//设置cell的高度为自动计算,只有才xib或者storyboard上自定义的cell才会生效,而且需要设置好约束

self.tableView.estimatedRowHeight = 240;//必须设置好预估值 self.tableView.rowheight =  UITableViewAutomaticDimension;//设置cell的高度为自动计算,只有才xib或者storyboard上自定义的cell才会生效,而且需要设置好约束

这两段代码可以写在viewdidload里,但是写在这会发生一个问题。就是继续使用UITableViewDataSource里的

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {}

这个方法后上述的方法就会失效

所以我会将  self.tableView.rowheight 以及 self.tableView.estimatedRowHeight这两个属性写在UITableViewDataSource的代理方法里

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath

{

if (indexPath.row == 0) {

return 60;

}

self.articleTableView.rowHeight = UITableViewAutomaticDimension;

self.articleTableView.estimatedRowHeight = 240;

return self.articleTableView.rowHeight;

}

2.在 -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath  {  }

//这个是label里面放的字符串

NSString *str = [NSString stringWithFormat:@"%@|%@",_sourceBuyingMoreDataDict[@"data"][@"belongUserName"],_sourceBuyingMoreDataDict[@"data"][@"belongDept"]];

//写上label的宽度跟字号   然后计算label的高度

CGFloat textHeight = [StringSize getHeight:str Size:CGSizeMake(DeviceWidth - 105, CGFLOAT_MAX) Font:14];

return textHeight + 21;

这样就实现tableviewcell的高度的自适应了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的TableView是指一种用于显示和编辑表格数据的UI控件。在Python中有多个库可以用来创建TableView,其中比较常用的是PyQt和Tkinter。这些库提供了丰富的功能和灵活的界面设计选项,使得开发者可以轻松创建自定义的表格视图。 在PyQt中,可以使用QTableView类来创建一个TableView。下面是一个简单的示例代码: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView, QVBoxLayout, QWidget from PyQt5.QtCore import Qt from PyQt5.QtGui import QStandardItemModel, QStandardItem if __name__ == "__main__": app = QApplication([]) window = QMainWindow() central_widget = QWidget(window) layout = QVBoxLayout(central_widget) # 创建表格模型 model = QStandardItemModel(4, 2) model.setHorizontalHeaderLabels(["Column 1", "Column 2"]) # 设置表格数据 for row in range(4): for column in range(2): item = QStandardItem(f"Row {row}, Column {column}") model.setItem(row, column, item) # 创建TableView并设置模型 table_view = QTableView() table_view.setModel(model) # 设置一些TableView的属性 table_view.setEditTriggers(QTableView.NoEditTriggers) # 禁止编辑 table_view.setSelectionMode(QTableView.SingleSelection) # 单选模式 table_view.setSelectionBehavior(QTableView.SelectRows) # 选中整行 # 将TableView添加到布局中,并将布局设置为窗口的中央部件 layout.addWidget(table_view) window.setCentralWidget(central_widget) # 显示窗口 window.show() app.exec() ``` 这段代码创建了一个有4行2列的TableView,并填充了一些示例数据。使用QStandardItemModel作为表格模型,并设置水平表头。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值