iOS开发-UITableView自定义Cell

简介:

UITableView在iOS中开发的重要地位是毋庸置疑的,基本上应用中用到的比例是一半左右,而且大部分情况都是需要自定义单元格的,这样用户看到的App才能更有美感。之前写过UITableView的基本用法,如果对UITableView不是很熟悉可以参考本人之前的博客,因此很多UITableView的知识点就默认你已经熟悉了,先看下自定义实现的效果,这是自定义的Cell最后展现的效果:

 

自定义Cell

1.首先新建一个CustomCell.xib文件,方式如下:

 

2.新建一个继承自UITableViewCell的CustomTableViewCell类,需要重写initWithStyle方法:

1
2
3
4
5
6
7
8
-(instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:( NSString  *)reuseIdentifier{
     self =[ super  initWithStyle:style reuseIdentifier:reuseIdentifier];
     if  ( self ) {
     NSArray  *views = [[ NSBundle  mainBundle] loadNibNamed:@ "CustomCell"  owner: nil  options: nil ];
     self =[views firstObject];
     }
     return  self ;
}

3.CustomCell.xib中拖入一个UITableViewCell,然后和CustomTableViewCell关联:

关联之后CustomTableViewCell多了一个属性:

1
@property  (weak,  nonatomic IBOutlet  UILabel *title;

UITableView加载Cell

1.viewDidLoad初始化UITableView:

1
2
3
4
self .tableView=[[UITableView alloc]initWithFrame:CGRectMake(10, 10,CGRectGetWidth( self .view.bounds)-20, CGRectGetHeight( self .view.bounds)-10)];
self .tableView.delegate= self ;
self .tableView.dataSource= self ;
[ self .view addSubview: self .tableView];

2.初始化标题数组travelArr

1
2
3
4
-( NSArray  *)travelArr{
     _travelArr=@[@ "北京-清迈" ,@ "北京-香港" ,@ "北京-东京" ,@ "北京-大阪" ,@ "北京-新加坡" ,@ "北京-维多利亚" ,@ "北京-纽约" ,@ "北京-夏威夷" ,@ "北京-维多利亚" ,@ "北京-柬埔寨" ];
     return  _travelArr;
}

3.实现UITableViewDataSource中的方法: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
-( NSInteger )numberOfSectionsInTableView:(UITableView *)tableView{
     return  1;
}
 
-( NSInteger )tableView:(UITableView *)tableView numberOfRowsInSection:( NSInteger )section{
     return  [ self .travelArr count];
}
 
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:( NSIndexPath  *)indexPath{
     static   NSString   *identifier=@ "CustomCell" ;
     CustomTableViewCell  *cell=[tableView dequeueReusableCellWithIdentifier:identifier];
     if  (cell== nil ) {
         cell=[[CustomTableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier];
     }
     cell.title.text=[ self .travelArr objectAtIndex:indexPath.row];
     return  cell;
}

4.实现UITableViewDelegate中的方法:

1
2
3
4
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:( NSIndexPath  *)indexPath{
     UITableViewCell *cell = [ self  tableView:tableView cellForRowAtIndexPath:indexPath];
     return  cell.frame.size.height;
}

简单的自定义大概就是如此了,如果有所收获,帮忙推荐下~

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4457350.html,如需转载请自行联系原作者

相关文章
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
19天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
111 66
|
5天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
29天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
1月前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
2月前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
2月前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!
|
物联网 Android开发 iOS开发
iOS开发 - 蓝牙学习的总结
iOS开发 - 蓝牙学习的总结
193 0
|
iOS开发
IOS开发---菜鸟学习之路--(九)-利用PullingRefreshTableView实现下拉刷新
本章主要讲解如何利用PullingRefreshTableView实现下拉(上拉)刷新的操作  PullingRefreshTableView 实现上下拉刷新的例子百度有很多,大家可以自己搜索下,先看下那些例子(一般搜索过来的都是一样的大家反正先把那部分内容先了解一下,然后再看本文档比较好。
894 0
|
iOS开发 Android开发 存储
IOS开发---菜鸟学习之路--(十)-实现新闻详细信息浏览页面
前面已经将了上下拉刷新 实现了上下拉刷新后我们的第一级界面就做好,接下来我们就需要实现 新闻详细信息浏览了 我个人认为一般实现新闻详细页面的方法有两种(主要是数据源的不同导致了方法的不同) 第一种是本身新闻就是一个链接地址,同时是已经处理好的适应手机浏览的网页 对于这种类型的数据源,我们直接在页面中放一个WebView控件,然后将URL传递过去就好了 另一种则是普通的包含标题、时间、内容、图片等数据结构的新闻内容(我们要实现的也是这种新闻,因为实现了这种之后, 我们就可以实现任何自定义的详细信息的页面了。
890 0