OC 日常笔记碎片知识
1.分析TableView的重要性.
-TableView是如何计算contentSize?
-什么控件会纳入contenSize?
*代码演示
#import "ViewController.h"
@interface ViewController () <UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, weak) UITableView *tableView;
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
//创建tableView
UITableView *tableView = [[UITableView alloc] init];
//设置尺寸
tableView.frame = CGRectMake(50, 100, 200, 300);
//背景颜色
tableView.backgroundColor = [UIColor grayColor];
//数源方法
tableView.dataSource = self;
//代理方法
tableView.delegate = self;
//每行高度
tableView.rowHeight = 40;
//赋值view
[self.view addSubview:tableView];
self.tableView = tableView;
}
//点击屏幕打印tableView的contentSize
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
NSLog(@"contentSize.height = %f", self.tableView.contentSize.height);
}
#pragma mark - <UITableViewDelegate>
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
NSLog(@"contentOffset.y = %f", tableView.contentOffset.y);
NSLog(@"contentSize.height = %f", tableView.contentSize.height);
}
#pragma mark - 数据源
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return 20;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *ID = @"cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
if (cell == nil) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
cell.backgroundColor = [UIColor redColor];
}
cell.textLabel.text = [NSString stringWithFormat:@"%@-%zd", self.class, indexPath.row];
return cell;
}
data:image/s3,"s3://crabby-images/3da5d/3da5dadf0ae55939b212c8f3c5be167478e8ca70" alt=""
data:image/s3,"s3://crabby-images/f3ae8/f3ae809221f79ee6f707799282116f7267a6f453" alt=""
*添加TableHeaderView与TableFooterView
//tableHeaderView
UIView *header = [[UIView alloc] init];
header.frame = CGRectMake(0, 0, tableView.frame.size.width, 64);
header.backgroundColor = [UIColor yellowColor];
tableView.tableHeaderView = header;
//tableFooterView
UIView *footer = [[UIView alloc] init];
footer.frame = CGRectMake(0, 0, tableView.frame.size.width, 49);
footer.backgroundColor = [UIColor blueColor];
tableView.tableFooterView = footer;
data:image/s3,"s3://crabby-images/99340/993409c9e45e7490feb424c0fe7ae66e69444c5e" alt=""
*那么思考普通的控件会纳入contentSize计算范围吗?
// 额外添加的子控件
UIView *textHeader = [[UIView alloc] init];
textHeader.frame = CGRectMake(0, -40, tableView.frame.size.width, 40);
textHeader.backgroundColor = [UIColor purpleColor];
[tableView addSubview:textHeader];
data:image/s3,"s3://crabby-images/0eab2/0eab270226076141fafb7627c9327aa7d60cc454" alt=""
*要如何显示额外添加的控件?
// 内边距
tableView.contentInset = UIEdgeInsetsMake(64, 0, 49, 0);
data:image/s3,"s3://crabby-images/fe89c/fe89c547643447b10e9c19de59c5477bca668f08" alt=""
*添加额外的滚动区域并没有改变contentSize,唯一改变是可视范围.
data:image/s3,"s3://crabby-images/c216d/c216df182f33ede566486b86d8a082ccf203224c" alt=""
data:image/s3,"s3://crabby-images/6c01d/6c01d215a0df54a9abacf59332a608582bb6ff65" alt=""
data:image/s3,"s3://crabby-images/1943a/1943a60395461b24cf1898e7722e6a5553621a40" alt=""
data:image/s3,"s3://crabby-images/5e26f/5e26fca967cc459a79372b0dac1cff4be18886c8" alt=""
data:image/s3,"s3://crabby-images/44715/447156ed92ec02d46759b104a1060333e209c3f7" alt=""
data:image/s3,"s3://crabby-images/69e82/69e82ffe0f49a3276243c537d62a8d56f207913a" alt=""
data:image/s3,"s3://crabby-images/45720/4572009e46ccd810a0735eb7e9cb274d0f68c2fc" alt=""
data:image/s3,"s3://crabby-images/d57db/d57db8fd1943665e7c3524271594739c6ecfd11e" alt=""
data:image/s3,"s3://crabby-images/7623b/7623b85a514417e689817d3b5a0435ff15eb75cb" alt=""
data:image/s3,"s3://crabby-images/89574/895745e205c054eebd6a7def2ef4c2183ab62f6a" alt=""
总结:
-
1-什么是tableView的内容(content)?
1.Cell
2.tableHeaderView\tableFooterView
3.sectionHeader\sectionFooter
-
2-contentSize.height :
意思是内容的高度.
-
3-contentOffset.y :
内容的偏移量(frame的顶部 - content的顶部)
-
4-contentInset :
内容周围的间距(内边距)
-
5-Frame:
1.frame.size.height : 矩形框的高度
2.frame : 以父控件内容的左上角为坐标原点
网友评论