全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

iOS开发之TableView实现完整的分割线详解

前言

在我们创建一个tableView的时候,细心的你有没有发现UITableViewCell左侧会有空白。而我们在开发中有这样的需求: 需要一根完整的分割线(去掉烦人的空白部分, 即分割线的宽度 == 屏幕的宽度)。

那么下面我就讲一讲该如何去掉空白的部分,显示完整的分割线。

这里我提供两种方法 :

第一种方法,也是我们最常用的方法,也是在我们自定义cell的时候所用到的. 即去掉tableView默认的分割线,自定义cell,重写setFrame: 方法即可

下面是具体代码实现:

步骤一 : 移除系统默认的分割线

// 设置分割线的样式为None.
self.tableView.separatorStyle = UITableViewCellSeparatorStyleNone;

tableView有个separatorStyle属性, 即分割线的样式.这是一个枚举类型. 我们按着command点击它进入他的属性中会发现如下代码:

typedef NS_ENUM(NSInteger, UITableViewCellSeparatorStyle) {
 UITableViewCellSeparatorStyleNone, //不显示分割线 
 UITableViewCellSeparatorStyleSingleLine,// 单线 
 UITableViewCellSeparatorStyleSingleLineEtched
 // 这种分离式仅支持分组样式表视图
 // This separator style is only supported for grouped style table views currently
}

步骤二 : 重写setFrame: 方法

注意重写setFrame: 方法是需要我们写在UITableViewCell中的, 上面也说过,这种方法适用于自定义cell.

下面是代码:

- (void)setFrame:(CGRect)frame {
 frame.origin.y += 1;  // 让cell的y值增加1(根据自己需要分割线的高度来进行调整)
 frame.size.height -= 1; // 让cell的高度减1
 [super setFrame:frame]; // 别忘了重写父类方法
}

通过上面两个步骤,就会去掉系统默认的分割线,生成我们自己的分割线. 这种方法是不是很简单呢? 如果需要自定义分割线的颜色,只需要设置`separatorColor`为你需要的颜色就可以啦.

第二种方法也很简单,此方法不需要我们自定义cell,使用默认的tableViewcell也可以成功.这里需要说明说的是:

     ios7中,UITableViewCell左侧会有默认15像素的空白.设置setSeparatorInset:UIEdgeInsetsZero 能将空白去掉.

     ios8中,setSeparatorInset:UIEdgeInsetsZero 的设置已经不起作用了.

下面是解决办法,首先在viewDidLoad方法加入以下代码:

if ([self.tableView respondsToSelector:@selector(setSeparatorInset:)]) {
// 如果tableView响应了setSeparatorInset: 这个方法,我们就将tableView分割线的内边距设为0.
  [self.tableView setSeparatorInset:UIEdgeInsetsZero];
}
if ([self.tableView respondsToSelector:@selector(setLayoutMargins:)]) {
// 如果tableView响应了setLayoutMargins: 这个方法,我们就将tableView分割线的间距距设为0.
  [self.tableView setLayoutMargins:UIEdgeInsetsZero];
}

然后在UITableView的代理方法中加入以下代码

- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath {
// 这两句的含义跟上面两句代码相同,就不做解释了
 if ([cell respondsToSelector:@selector(setSeparatorInset:)]) {
   [cell setSeparatorInset:UIEdgeInsetsZero];
  }
 if ([cell respondsToSelector:@selector(setLayoutMargins:)]) {
   [cell setLayoutMargins:UIEdgeInsetsZero];
  }
}

总结

以上就是这篇文章的全部内容了,通过上述两个步骤也可以实现让cell 的分割线完整的显示出来. 小伙伴们,赶紧试试吧.  如果有什么更好的办法,或者是其他的思路可以留言交流。 同时非常欢迎提出宝贵的意见.希望本文的内容对大家的学习或者工作能带来一定的帮助。


# ios  # tableview  # 分割线  # tableviewcell分割线  # 分割线高度  # 解决iOS11刷新tableview会出现漂移的现象  # IOS实现左右两个TableView联动效果  # iOS tableView实现单选和多选的实例代码  # 详解iOS开发中UItableview控件的数据刷新功能的实现  # iOS中TableView如何统一数据源代理详解  # 自定义  # 重写  # 会有  # 设为  # 种方法  # 两句  # 就将  # 自己的  # 的是  # 有什么  # 我就  # 就会  # 这种方法  # 有个  # 不需要  # 为你  # 两种  # 中有  # 其他的 


相关文章: 建站之星如何一键生成手机站?  家庭建站与云服务器建站,如何选择更优?  如何确保FTP站点访问权限与数据传输安全?  建站之星如何修改网站生成路径?  建站OpenVZ教程与优化策略:配置指南与性能提升  制作网页的网站有哪些,电脑上怎么做网页?  建站之星ASP如何实现CMS高效搭建与安全管理?  如何用低价快速搭建高质量网站?  香港服务器WordPress建站指南:SEO优化与高效部署策略  孙琪峥织梦建站教程如何优化数据库安全?  制作营销网站公司,淘特是干什么用的?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  C++如何使用std::optional?(处理可选值)  如何通过二级域名建站提升品牌影响力?  如何通过IIS搭建网站并配置访问权限?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  建站之星安装路径如何正确选择及配置?  郑州企业网站制作公司,郑州招聘网站有哪些?  设计网站制作公司有哪些,制作网页教程?  建站主机与服务器功能差异如何区分?  高防服务器租用指南:配置选择与快速部署攻略  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  如何在阿里云部署织梦网站?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  宝塔面板如何快速创建新站点?  javascript中的try catch异常捕获机制用法分析  PHP正则匹配日期和时间(时间戳转换)的实例代码  浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  如何通过WDCP绑定主域名及创建子域名站点?  如何续费美橙建站之星域名及服务?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何在阿里云香港服务器快速搭建网站?  简单实现Android文件上传  已有域名和空间,如何快速搭建网站?  如何配置IIS站点权限与局域网访问?  如何彻底删除建站之星生成的Banner?  长沙做网站要多少钱,长沙国安网络怎么样?  建站主机功能解析:服务器选择与快速搭建指南  详解jQuery停止动画——stop()方法的使用  如何快速搭建虚拟主机网站?新手必看指南  建站之星logo尺寸如何设置最合适?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  宝塔建站助手安装配置与建站模板使用全流程解析  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  Android自定义listview布局实现上拉加载下拉刷新功能 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。