iOS开发UI篇—UITableview控件基本使用

简介:

一、一个简单的英雄展示程序

NJHero.h文件代码(字典转模型)

复制代码
 1 #import <Foundation/Foundation.h>
 2  3 @interface NJHero : NSObject
 4 /**
 5  * 头像
 6 */  7 @property (nonatomic, copy) NSString *icon;
 8 /**
 9  * 名称
10 */ 11 @property (nonatomic, copy) NSString *name;
12 /**
13  * 描述
14 */ 15 @property (nonatomic, copy) NSString *intro;
16 17 - (instancetype)initWithDict:(NSDictionary *)dict;
18 + (instancetype)heroWithDict:(NSDictionary *)dict;
19 @end
复制代码

NJViewController.m文件代码

复制代码
 1 #import "NJViewController.h"  2 #import "NJHero.h"  3  4 @interface NJViewController ()<UITableViewDataSource, UITableViewDelegate>
 5 /**
 6  * 保存所有的英雄数据
 7 */  8 @property (nonatomic, strong) NSArray *heros;
 9 @property (weak, nonatomic) IBOutlet UITableView *tableView;
10 11 @end 12 13 @implementation NJViewController
14 15 #pragma mark - 懒加载
16 - (NSArray *)heros
17 {
18 if (_heros == nil) {
19 // 1.获得全路径 20 NSString *fullPath = [[NSBundle mainBundle] pathForResource:@"heros" ofType:@"plist"];
21 // 2.更具全路径加载数据 22 NSArray *dictArray = [NSArray arrayWithContentsOfFile:fullPath];
23 // 3.字典转模型 24 NSMutableArray *models = [NSMutableArray arrayWithCapacity:dictArray.count];
25 for (NSDictionary *dict in dictArray) {
26 NJHero *hero = [NJHero heroWithDict:dict];
27  [models addObject:hero];
28  }
29 // 4.赋值数据 30 _heros = [models copy];
31  }
32 // 4.返回数据 33 return _heros;
34 }
35 36 - (void)viewDidLoad
37 {
38  [super viewDidLoad];
39 // 设置Cell的高度
40 // 当每一行的cell高度一致的时候使用属性设置cell的高度 41 self.tableView.rowHeight = 60;
42 self.tableView.delegate = self;
43 }
44 45 #pragma mark - UITableViewDataSource
46 // 返回多少组 47 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
48 {
49 return 1;
50 }
51 // 返回每一组有多少行 52 - (NSInteger) tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
53 {
54 return self.heros.count;
55 }
56 // 返回哪一组的哪一行显示什么内容 57 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
58 {
59 // 1.创建CELL 60 UITableViewCell *cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:nil];
61 // 2.设置数据
62 // 2.1取出对应行的模型 63 NJHero *hero = self.heros[indexPath.row];
64 // 2.2赋值对应的数据 65 cell.textLabel.text = hero.name;
66 cell.detailTextLabel.text = hero.intro;
67 cell.imageView.image = [UIImage imageNamed:hero.icon];
68 // 3.返回cell 69 return cell;
70 }
71 #pragma mark - UITableViewDelegate
72 /* 73 // 当每一行的cell的高度不一致的时候就使用代理方法设置cell的高度
74 - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
75 {
76  if (1 == indexPath.row) {
77  return 180;
78  }
79  return 44;
80 }
81 */ 82 83 #pragma mark - 控制状态栏是否显示
84 /**
85  * 返回YES代表隐藏状态栏, NO相反
86 */ 87 - (BOOL)prefersStatusBarHidden
88 {
89 return YES;
90 }
91 @end
复制代码

实现效果:

代码注意点:

(1)在字典转模型的代码处用下面的代码,为可变数组分配dictArray.count个存储空间,可以提高程序的性能

NSMutableArray *models = [NSMutableArrayarrayWithCapacity:dictArray.count];

(2)设置cell的高度

有三种办法可以设置cell的高度

1) 可以在初始加载方法中设置,self.tableView.rowHeight = 60;这适用于当每一行的cell高度一致的时候,使用属性设置cell的高度。

2)在storyboard中设置,适用于高度一致

3)当每一行的cell的高度不一致的时候就使用代理方法设置cell的高度

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

{

if (1 == indexPath.row) {

return 180;

}

return 44;

}

二、cell的一些属性

代码示例:

复制代码
 1 #import "NJViewController.h"  2 #import "NJHero.h"  3  4 @interface NJViewController ()<UITableViewDataSource, UITableViewDelegate>
 5 /**
 6  * 保存所有的英雄数据
 7 */  8 @property (nonatomic, strong) NSArray *heros;
 9 @property (weak, nonatomic) IBOutlet UITableView *tableView;
 10  11 @end  12  13 @implementation NJViewController
 14  15 #pragma mark - 懒加载
 16 - (NSArray *)heros
 17 {
 18 if (_heros == nil) {
 19 // 1.获得全路径  20 NSString *fullPath = [[NSBundle mainBundle] pathForResource:@"heros" ofType:@"plist"];
 21 // 2.更具全路径加载数据  22 NSArray *dictArray = [NSArray arrayWithContentsOfFile:fullPath];
 23 // 3.字典转模型  24 NSMutableArray *models = [NSMutableArray arrayWithCapacity:dictArray.count];
 25 for (NSDictionary *dict in dictArray) {
 26 NJHero *hero = [NJHero heroWithDict:dict];
 27  [models addObject:hero];
 28  }
 29 // 4.赋值数据  30 _heros = [models copy];
 31  }
 32 // 4.返回数据  33 return _heros;
 34 }
 35  36 - (void)viewDidLoad
 37 {
 38  [super viewDidLoad];
 39 // 设置Cell的高度
 40 // 当每一行的cell高度一致的时候使用属性设置cell的高度  41 self.tableView.rowHeight = 60;
 42 self.tableView.delegate = self;
 43  44 }
 45  46 #pragma mark - UITableViewDataSource
 47 // 返回多少组  48 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
 49 {
 50 return 1;
 51 }
 52 // 返回每一组有多少行  53 - (NSInteger) tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
 54 {
 55 return self.heros.count;
 56 }
 57 // 返回哪一组的哪一行显示什么内容  58 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
 59 {
 60 // 1.创建CELL  61 UITableViewCell *cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:nil];
 62 // 2.设置数据
 63 // 2.1取出对应行的模型  64 NJHero *hero = self.heros[indexPath.row];
 65 // 2.2赋值对应的数据  66 cell.textLabel.text = hero.name;
 67 cell.detailTextLabel.text = hero.intro;
 68 cell.imageView.image = [UIImage imageNamed:hero.icon];
 69  70 // 2.3设置cell的辅助视图
 71 // cell.accessoryType = UITableViewCellAccessoryDisclosureIndicator;  72 if (0 == indexPath.row) {
 73 cell.accessoryView = [UIButton buttonWithType:UIButtonTypeContactAdd];
 74 }else  75  {
 76 cell.accessoryView = [[UISwitch alloc] init];
 77  }
 78 // UIButton *btn = [[UIButton alloc] init];
 79 // btn.backgroundColor = [UIColor redColor];
 80 // cell.accessoryView = btn;
 81  82  83 // 2.4设置cell的背景颜色  84 cell.backgroundColor = [UIColor blueColor];
 85  86 // 设置默认状态的背景
 87 // UIView *view = [[UIView alloc] init];
 88 // view.backgroundColor = [UIColor blueColor];
 89 // cell.backgroundView = view;  90  91 UIImageView *iv = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"buttondelete"]];
 92 cell.backgroundView = iv;
 93  94 // 设置选中状态的背景  95 UIView *view2 = [[UIView alloc] init];
 96 view2.backgroundColor = [UIColor purpleColor];
 97 cell.selectedBackgroundView = view2;
 98 // 3.返回cell  99 return cell;
100 }
101 102 103 #pragma mark - 控制状态栏是否显示
104 /**
105  * 返回YES代表隐藏状态栏, NO相反
106 */ 107 - (BOOL)prefersStatusBarHidden
108 {
109 return YES;
110 }
111 @end
复制代码

实现效果:

cell的一些属性:

(1)设置cell的辅助视图,设置cell.accessoryView(系统提供了枚举型,也可以自定义@父类指针指向子类对象);

(2)设置cell的背景颜色,有两种方式可以设置cell的背景颜色:

通过backgroundColor 和 backgroundView都可以设置cell的背景。但是backgroundView 的优先级比 backgroundColor的高,所以如果同时设置了backgroundColor和backgroundView, 那么backgroundView会盖住backgroundColor

示例:cell.backgroundColor = [UIColorblueColor];

(3)设置cell默认状态的背景

示例1:

   UIView *view = [[UIView alloc] init];

   view.backgroundColor = [UIColor blueColor];

  cell.backgroundView = view;

示例2:

UIImageView *iv = [[UIImageViewalloc] initWithImage:[UIImageimageNamed:@"buttondelete"]];

cell.backgroundView = iv;(父类指针指向子类对象,可以使用图片用简单的操作设置绚丽的效果)

(4)设置cell选中状态的背景

示例:

  UIView *view2 = [[UIView alloc] init];

view2.backgroundColor = [UIColorpurpleColor];

cell.selectedBackgroundView = view2;

三、tableview的一些属性

代码示例:

复制代码
 1 #import "NJViewController.h"  2  3 @interface NJViewController ()<UITableViewDataSource>
 4  5 @end  6  7 @implementation NJViewController
 8  9 - (void)viewDidLoad
10 {
11  [super viewDidLoad];
12 13 // 1.创建tableview 14 UITableView *tableview = [[UITableView alloc] init];
15 tableview.frame = self.view.bounds;
16 17 // 2.设置数据源 18 tableview.dataSource =self;
19 20 // 3.添加tableview到view 21  [self.view addSubview:tableview];
22 23 // 4.设置分割线样式
24 // tableview.separatorStyle = UITableViewCellSeparatorStyleNone;
25 26 // 5.设置分割线颜色 27  接收的参数是颜色的比例值
28 tableview.separatorColor = [UIColor colorWithRed:0/255.0 green:255/255.0 blue:0/255.0 alpha:255/255.0];
29 30 // 设置tableview的头部视图 31 tableview.tableHeaderView = [UIButton buttonWithType:UIButtonTypeContactAdd];
32 tableview.tableFooterView = [[UISwitch alloc] init];
33 }
34 35 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
36 {
37 return 1;
38 }
39 - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
40 {
41 return 10;
42 }
43 44 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
45 {
46 // 1.创建cell 47 UITableViewCell *cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];
48 49 // 2.设置cell的数据 50 cell.textLabel.text = [NSString stringWithFormat:@"%d", indexPath.row ];
51 52 // 3.返回cell 53 return cell;
54 }
55 56 - (BOOL)prefersStatusBarHidden
57 {
58 return YES;
59 }
60 @end
复制代码

实现效果:

tableview的一些属性:

(1)设置分割样式(tableview.separatorStyle),这是个枚举类型

(2)设置分割线的颜色,可以直接使用系统给出的颜色,如果系统给定的颜色不能满足需求时,也可以自定义。

  补充:颜色分为24位和32位的,如下

24bit颜色

R 8bit 0 ~ 255

G 8bit 0 ~ 255

B 8bit 0 ~ 255

32bit颜色

A 8bit 0 ~ 255(tou)

R 8bit

G 8bit

B 8bit

#ff ff ff 白色

#00 00 00 黑色

#ff 00 00 红色

#255 00 00

设置为自定义颜色的实例:tableview.separatorColor = [UIColorcolorWithRed:0/255.0green:255/255.0blue:0/255.0alpha:255/255.0];

//接收的参数是颜色的比例值

(3)设置顶部和底部视图

tableview.tableHeaderView //顶部

tableview.tableFooterView //底部

目录
打赏
0
0
0
0
4
分享
相关文章
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
203 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
35 11
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
TIS 是一款基于Web-UI的开源大数据集成工具,通过与人大金仓Kingbase的深度整合,提供高效、灵活的实时数据集成方案。它支持增量数据监听和实时写入,兼容MySQL、PostgreSQL和Oracle模式,无需编写复杂脚本,操作简单直观,特别适合非专业开发人员使用。TIS率先实现了Kingbase CDC连接器的整合,成为业界首个开箱即用的Kingbase CDC数据同步解决方案,助力企业数字化转型。
135 5
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
66 10
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
Vue Amazing UI 是一个基于 Vue 3、TypeScript、Vite 等最新技术栈开发构建的现代化组件库,包含丰富的 UI 组件和常用工具函数,并且持续不断维护更新中。另外,组件库全量使用 TypeScript,支持自动按需引入和 Tree Shaking 等,能够显著提升开发效率,降低开发成本。
121 5
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
HarmonyOS ArkTS声明式UI开发实战教程
本文深入探讨了ArkTS作为HarmonyOS生态中新一代声明式UI开发框架的优势与应用。首先对比了声明式与命令式开发的区别,展示了ArkTS如何通过直观高效的代码提升可维护性。接着分析了其核心三要素:数据驱动、组件化和状态管理,并通过具体案例解析布局体系、交互组件开发技巧及复杂状态管理方案。最后,通过构建完整TODO应用实战,结合调试优化指南,帮助开发者掌握声明式UI设计精髓,感受ArkTS的独特魅力。文章鼓励读者通过“破坏性实验”建立声明式编程思维,共同推动HarmonyOS生态发展。
82 3
Harmony os next~UI开发与ArkUI框架
鸿蒙OS的UI开发基于ArkUI框架,采用声明式编程,简化开发流程。五大核心组件(Text、Button、List、Grid、Flex)助力高效布局,支持数据绑定与动态更新。事件响应机制灵敏,适合构建交互丰富的应用。实战技巧包括规范命名、样式复用和调试方法。掌握这些,轻松开发鸿蒙应用。下期预告:分布式开发,记得带上烤冷面!
58 0
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
鸿蒙NEXT开发声明式UI是咋回事?
【10月更文挑战第15天】鸿蒙NEXT的声明式UI基于ArkTS,提供高效简洁的开发体验。ArkTS扩展了TypeScript,支持声明式UI描述、自定义组件及状态管理。ArkUI框架则提供了丰富的组件、布局计算和动画能力。开发者仅需关注数据变化,UI将自动更新,简化了开发流程。此外,其前后端分层设计与编译时优化确保了高性能运行,利于生态发展。通过组件创建、状态管理和渲染控制等方式,开发者能快速构建高质量的鸿蒙应用。
263 3
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
3396 2
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)

热门文章

最新文章

  • 1
    苹果app上架-ios上架苹果商店app store 之苹果支付In - App Purchase内购配置-优雅草卓伊凡
    88
  • 2
    苹果app上架app store 之苹果开发者账户在mac电脑上如何使用钥匙串访问-发行-APP发布证书ios_distribution.cer-优雅草卓伊凡
    54
  • 3
    uniapp云打包ios应用证书的获取方法,生成指南
    82
  • 4
    iOS|解决 setBrightness 调节屏幕亮度不生效的问题
    129
  • 5
    iOS|记一名 iOS 开发新手的前两次 App 审核经历
    37
  • 6
    iOS各个证书生成细节
    54
  • 7
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    255
  • 8
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    81
  • 9
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    94
  • 10
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    77
  • 相关课程

    更多

    相关实验场景

    更多
    AI助理

    你好,我是AI助理

    可以解答问题、推荐解决方案等