iOS中 自定义cell升级版 (高级)
接上次分享的自定义cell进行了优化:http://blog.csdn.net/qq_31810357/article/details/49611255
指定根视图:
- self.window.rootViewController = [[UINavigationController alloc] initWithRootViewController:[[RootTableViewController alloc] initWithStyle:UITableViewStylePlain]];
RootTableViewController.m
- #import "WGModel.h"
- #import "WGCell.h"
- @interface RootTableViewController ()
- @property (nonatomic, strong) NSMutableDictionary *dataDict;
- @end
- @implementation RootTableViewController
- - (void)viewDidLoad
- {
- [super viewDidLoad];
- self.dataDict = [NSMutableDictionary dictionary];
- [self.tableView registerClass:[WGCell class] forCellReuseIdentifier:@"cell"];
- [self loadDataAndShow];
- }
请求数据:
- - (void)loadDataAndShow
- {
- NSURL *url = [NSURL URLWithString:@"http://api.breadtrip.com/trips/2387133727/schedule/"];
- NSURLRequest *request = [NSURLRequest requestWithURL:url];
- [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
- if (data != nil) {
- NSArray *array = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];
- for (NSDictionary *dict in array) {
- NSString *key = dict[@"date"];
- NSArray *placesArray = dict[@"places"];
- NSMutableArray *mutableArray = [NSMutableArray array];
- for (NSDictionary *placesDict in placesArray) {
- WGModel *model = [[WGModel alloc] init];
- [model setValuesForKeysWithDictionary:placesDict];
- model.isShow = NO;
- [mutableArray addObject:model];
- }
- [self.dataDict setObject:mutableArray forKey:key];
- }
- [self.tableView reloadData];
- }
- }];
- }
#pragma mark - Table view data source
- - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
- {
- return self.dataDict.allKeys.count;
- }
- - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
- {
- NSString *key = self.dataDict.allKeys[section];
- return [self.dataDict[key] count];
- }
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- WGCell *cell = [tableView dequeueReusableCellWithIdentifier:@"cell" forIndexPath:indexPath];
- NSString *key = self.dataDict.allKeys[indexPath.section];
- NSMutableArray *mutableArray = self.dataDict[key];
- WGModel *model = mutableArray[indexPath.row];
- [cell configureCellWithModel:model];
- if (model.isShow == YES) {
- [cell showTableView];
- } else {
- [cell hiddenTableView];
- }
- return cell;
- }
自适应高
- - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- NSString *key = self.dataDict.allKeys[indexPath.section];
- NSMutableArray *mutableArray = self.dataDict[key];
- WGModel *model = mutableArray[indexPath.row];
- if (model.isShow) {
- return (model.pois.count + 1) * 44;
- } else {
- return 44;
- }
- }
点击cell会走的方法
- - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
- {
- NSString *key = self.dataDict.allKeys[indexPath.section];
- NSMutableArray *mutableArray = self.dataDict[key];
- WGModel *model = mutableArray[indexPath.row];
- model.isShow = !model.isShow;
- [self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
- }
自定义cell
- //.h
- #import <UIKit/UIKit.h>
- @class WGModel;
- @interface WGCell : UITableViewCell<UITableViewDataSource, UITableViewDelegate>
- @property (nonatomic, strong) UILabel *aLabel;
- @property (nonatomic, strong) UITableView *tableView;
- - (void)configureCellWithModel:(WGModel *)model;
- - (void)showTableView;
- - (void)hiddenTableView;
- @end
- //.m
- #import "WGCell.h"
- #import "WGModel.h"
- @interface WGCell ()
- @property (nonatomic, strong) NSMutableArray *dataArray;
- @end
- @implementation WGCell
- - (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
- {
- if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
- self.dataArray = [NSMutableArray array];
- [self addAllViews];
- }
- return self;
- }
- - (void)addAllViews
- {
- self.aLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 44)];
- self.aLabel.backgroundColor = [UIColor greenColor];
- [self.contentView addSubview:self.aLabel];
- self.tableView = [[UITableView alloc] initWithFrame:CGRectMake(0, 44, [UIScreen mainScreen].bounds.size.width, 0) style:UITableViewStylePlain];
- self.tableView.delegate = self;
- self.tableView.dataSource = self;
- [self.tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"testCell"];
- // [self.contentView addSubview:self.tableView];
- }
- - (void)showTableView
- {
- [self.contentView addSubview:self.tableView];
- }
- - (void)hiddenTableView
- {
- [self.tableView removeFromSuperview];
- }
- - (void)configureCellWithModel:(WGModel *)model
- {
- [self.dataArray removeAllObjects];
- self.aLabel.text = model.place[@"name"];
- NSArray *array = model.pois;
- for (NSDictionary *dict in array) {
- NSString *str = dict[@"name"];
- [self.dataArray addObject:str];
- }
- CGRect frame = self.tableView.frame;
- frame.size.height = 44 * array.count;
- self.tableView.frame = frame;
- [self.tableView reloadData];
- }
- - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
- {
- return 1;
- }
- - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
- {
- return self.dataArray.count;
- }
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"testCell" forIndexPath:indexPath];
- NSString *str = self.dataArray[indexPath.row];
- cell.textLabel.text = str;
- return cell;
- }
准备一个model类
- //.h
- #import <Foundation/Foundation.h>
- @interface WGModel : NSObject
- @property (nonatomic, assign) BOOL isShow;
- @property (nonatomic, strong) NSDictionary *place;
- @property (nonatomic, strong) NSArray *pois;
- @end
- //.m
- #import "WGModel.h"
- @implementation WGModel
- - (void)setValue:(id)value forUndefinedKey:(NSString *)key
- {
- }
- @end
最终效果:
每日更新关注:http://weibo.com/hanjunqiang
新浪微博
iOS中 自定义cell升级版 (高级)的更多相关文章
- ios中自定义cell 设置cell的分组结构
ios系统默认的cell并不能满足我们的需求 这个时候就需要自定义我们的cell 自定义cell为分组的时候 需要设置分组样式 以下是我常用分组的二种方法: 第一是 在自定义的UITableView ...
- iOS中 自定义cell分割线/分割线偏移 韩俊强的博客
在项目开发中我们会常常遇到tableView 的cell分割线显示不全,左边会空出一截像素,更有甚者想改变系统的分割线,并且只要上下分割线的一个等等需求,今天重点解决以上需求,仅供参考: 每日更新关注 ...
- iOS 中自定义 cell,点击cell的时候文字不出现的原因
解决方案: 在setSelected方法中设置要显示label的背景颜色即可
- ios中自定义tableView,CollectionView的cell什么时候用nib加载,什么时候用标识重用
做了一段时间的iOS,在菜鸟的路上还有很长的路要走,把遇到的问题记下来,好记性不如烂笔头. 在项目开发中大家经常会用到tableView和collectionView两个控件,然而在cell的自定义上 ...
- ios之UI中自定义cell
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- iOS中 UITableViewCell cell划线那些事 韩俊强的博客
每日更新关注:http://weibo.com/hanjunqiang 在开发中经常遇到cell分割线显示不全或者想自定义线的宽高等; 最近总结了一下,希望帮到大家: 1.不想划线怎么办? Table ...
- ios中自定义checkbox
//自定义button#import <UIKit/UIKit.h> @interface CKButton : UIButton @end #import "CKButton. ...
- iOS 获取自定义cell上按钮所对应cell的indexPath.row的方法
在UITableView或UICollectionView的自定义cell中创建一button,在点击该按钮时知道该按钮所在的cell在UITableView或UICollectionView中的行数 ...
- iOS中自定义UITableViewCell的用法
1.先创建一个View继承 UITableViewCell并使用xib快速建立模型. #import <UIKit/UIKit.h> #import "Score.h" ...
随机推荐
- 解决Spring Boot 使用RedisTemplate 存储键值出现乱码 \xac\xed\x00\x05t\x00
spring-data-redis的RedisTemplate<K, V>模板类在操作redis时默认使用JdkSerializationRedisSerializer来进行序列化解决方法 ...
- Apache软件基金会项目百度百科链接
Apache软件基金会 顶级项目 ▪ ActiveMQ ▪ Ant ▪ Apache HTTP Server ▪ APR ▪ Beehive ▪ Camel ▪ Cassandra ▪ Cayenne ...
- 使用Fiddler改变线上js文件的引用路径
一般的项目开发都是先在本地环境开发,测试环境中完成测试,最后再提交到线上环境. 但是由于版本构建工具有时出现bug或者一些缓存的因素导致测试环境代码可能和线上不一样,这是多么蓝瘦的事情.此处说的是在原 ...
- 深入理解Lambda函数及其用法
Lambda函数又称匿名函数,匿名函数就是没有名字的函数,函数没有名字也行?当然可以啦.有些函数如果只是临时一用,而且它的业务逻辑也很简单时,就没必要非给它取个名字不可. 先来看个简单lambda函数 ...
- 网络流24题第一题(luogu2796飞行员配对方案)
飞行员配对方案 二分图裸题,可以拿最大流怼. 题目背景 第二次世界大战时期.. 题目描述 英国皇家空军从沦陷国征募了大量外籍飞行员.由皇家空军派出的每一架飞机都需要配备在航行技能和语言上能互相配合的2 ...
- 将luarocks整合进openresty
缘由 随着功能需求的深入, openresty领域的包已经不够用了, 需要lua领域本身累积的库, 也就是luarocks. 本文讲解了windows 10桌面和ubuntu server两套系统的方 ...
- ROS新功能包PlotJuggler绘图
http://www.ros.org/news/2017/01/new-package-plotjuggler.html PlotJuggler,一个基于Qt的应用程序,允许用户加载,搜索和绘图数据. ...
- Appium移动自动化测试(五)--app控件获取之uiautomatorviewer
初探 在Android的SDk提供了以下的工具来支持我们进行UI自动化测试: uiautomatorviewer:用来扫描和分析Android应用程序的UI控件的工具. uiautomator:一个包 ...
- 输入一个正数n,输出所有和为n连续正数序列。例如输入15,由于1+2+3+4+5=4+5+6=7+8=15,所以输出3个连续序列1-5、4-6和7-8。
输入一个正数n,输出所有和为n连续正数序列.例如输入15,由于1+2+3+4+5=4+5+6=7+8=15,所以输出3个连续序列1-5.4-6和7-8. #define N 15 void findS ...
- 详解EBS接口开发之采购订单导入
采购订单常用标准表简介 1.1 常用标准表 如下表中列出了与采购订单导入相关的表和说明: 表名 说明 其他信息 po.po_headers_all 采购订单头 采购订单号,采购类型,供应商,地点, ...