推荐一个网站 http://objccn.io/ 我这两天才开始看 获益匪浅

看了第一篇文章 《更轻量的View Controllers》感觉写的不错 感觉作者 原文地址 http://objccn.io/issue-1-1/

示例项目的代码有点旧 Xcode6运行出错 懒的理了 所以我大概模仿他写了一点测试代码 运行环境Xcode7/iOS9

轻量化ViewControllers 顾名思义 就是把ViewController的代码进行简化 让控制器更简单 更清晰

一、把DataSource和其他potocols分离出控制器

因为做项目很多控制器都是TableViewController,所以必须要有数据源(TableViewDataSource)输入,一般DataSource的3个方法都在控制器里

我们的目的就是要把他分离出来,方法就是自定义一个类,然后控制器调用这个类

并且这个数据源类是通用的,别的TableViewController或者有定义了tableView/collectionView的控制器都可以调用

自定义ArrayDataSource类

1.定义一个Block,用于传递cell和数据

typedef void (^TableViewCellPassBlock)(id cell,id item);

2.定义一个方法给控制器调用,用于初始化ArrayDataSource类(需要暴露在.h文件中)

@property(nonatomic,strong) NSArray *items;

@property(nonatomic,copy) NSString *cellIdentifier;

@property(nonatomic,copy) TableViewCellPassBlock passBlock;

/**


*  初始化数据源的方法

*  @param anItems         用于接受数据的数组

*  @param aCellIdentifier 接收cell的ID

*  @param aPassBlock      接收传递的Block

*/

- (id)initWithItems:(NSArray *)anItems

  cellIdentifier:(NSString *)aCellIdentifier

 passBlock:(TableViewCellPassBlock)aPassBlock
{
self = [super init];
if(self){
self.items = anItems;
self.cellIdentifier = aCellIdentifier;
self.passBlock = [aPassBlock copy];
}
return self;
}

3.然后就是数据源的方法

/** 这个方法找出数组的数据 后面要用到*/
- (id)itemAtIndexPath:(NSIndexPath *)indexPath
{
return self.items[(NSUInteger) indexPath.row];
} #pragma mark - UITableViewDataSource - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return self.items.count;
} - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:self.cellIdentifier
forIndexPath:indexPath];
id item = [self itemAtIndexPath:indexPath];
self.passBlock(cell, item);
return cell;
}

ArrayDataSource类就这样定义完成了

接下来是控制器的调用

只需要写以下几行代码便可以设置tableView的数据源,不用每个控制器都写那三个方法

    //数组传数据是接下来要简化的,后面会详细说明
  NSArray *arr = [AppDelegate sharedDelegate].returnModel.returnData;
//使用Block回调,传递cell和模型数据
TableViewCellPassBlock passBlock = ^(TestModelCell *cell,TestModel *model){
    //测试方法,只是传递model给cell,这个方法用分类写的,自定义cell的分类
[cell setName:model];
};
  //初始化并设置tableView的数据源
self.dataSource = [[ArrayDataSource alloc] initWithItems:arr cellIdentifier:@"TestModelCell" passBlock:passBlock];
self.tableView.dataSource = self.dataSource;

二、将业务逻辑放到model中

一些跟控制器无关的代码可以放到模型中

测试代码我写了一个TestModel,只有一个属性和一个初始化方法

@property(nonatomic,copy) NSString *name;

- (instancetype)initWithName:(NSString *)name;

然后又写了一个model,因为要返回数据所以我叫ReturnModel

在.h文件中暴露的方法

//类方法,创建的时候用这个方法
+ (instancetype)returnModel;

//这个方法用于返回数据
- (NSArray *)returnData;

然后在.m文件中

+ (instancetype)returnModel
{
return [[self alloc] init];
} - (id)init
{
self = [super init];
if (self) {
  
    //调用方法执行业务逻辑的方法
[self doSomething];
} return self;
}

//可以在这个方法中执行与控制器无关的业务逻辑
- (void)doSomething
{
NSLog(@"try to do something");
} //在这个方法中返回模型数据,数据略

- (NSArray *)returnData

{

  NSArray *arr = [[NSArray alloc] initWithObject:...];

  return arr;

}

思路就是在返回数据的模型类中执行业务逻辑,在创建类的时候执行

在AppDelegate中添加方法和属性,并且暴露在.h文件中

+ (instancetype)sharedDelegate
{
return [UIApplication sharedApplication].delegate;
} @synthesize returnModel = _returnModel; - (ReturnModel *)returnModel
{
if (_returnModel == nil) {
_returnModel = [ReturnModel returnModel];
}
return _returnModel;
}

所以控制器直接调用方法得到数据

NSArray *arr = [AppDelegate sharedDelegate].returnModel.returnData;

这时候控制器已经很简化了

可以把网络请求也放在model层

最后吐槽一句博客园的代码高亮好难看

轻量化ViewControllers,读文章做的总结的更多相关文章

  1. iOS Method Swizzling和分类的妙用AppDelegate轻量化处理

    http://www.cocoachina.com/ios/20151117/14167.html 简介 在iOS工程中,AppDelegate往往会有上千行,甚至几千行,这样就会给维护AppDele ...

  2. 轻量化模型之MobileNet系列

    自 2012 年 AlexNet 以来,卷积神经网络在图像分类.目标检测.语义分割等领域获得广泛应用.随着性能要求越来越高,AlexNet 已经无法满足大家的需求,于是乎各路大牛纷纷提出性能更优越的 ...

  3. CNN结构演变总结(二)轻量化模型

    CNN结构演变总结(一)经典模型 导言: 上一篇介绍了经典模型中的结构演变,介绍了设计原理,作用,效果等.在本文,将对轻量化模型进行总结分析. 轻量化模型主要围绕减少计算量,减少参数,降低实际运行时间 ...

  4. 卷积神经网络学习笔记——轻量化网络MobileNet系列(V1,V2,V3)

    完整代码及其数据,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/DeepLearningNote 这里结合网络的资料和Mo ...

  5. 轻量化模型系列--GhostNet:廉价操作生成更多特征

    ​  前言  由于内存和计算资源有限,在嵌入式设备上部署卷积神经网络 (CNN) 很困难.特征图中的冗余是那些成功的 CNN 的一个重要特征,但在神经架构设计中很少被研究. 论文提出了一种新颖的 Gh ...

  6. 基于WebGL/Threejs技术的BIM模型轻量化之图元合并

    伴随着互联网的发展,从桌面端走向Web端.移动端必然的趋势.互联网技术的兴起极大地改变了我们的娱乐.生活和生产方式.尤其是HTML5/WebGL技术的发展更是在各个行业内引起颠覆性的变化.随着WebG ...

  7. 铁大Facebook轻量化界面NABCD

    界面轻量化: N:满足了用户更快速.更直接.更方便寻求自己所要信息的需求,不被复杂界面以及各种广告所困扰. A:我们将会用Bootstrap工具包开发前端界面,Bootstrap是基于jQuery框架 ...

  8. js便签笔记(14)——用nodejs搭建最简单、轻量化的http server

    1. 引言 前端程序猿主要关注的是页面,你可能根本就用不到.net,java,php等后台语言. 但是你制作出来的网页总要运行.总要测试吧?——那就免不了用到http server.我先前都是用vis ...

  9. 【本地服务器】用nodejs搭建最简单、轻量化的http server

    1. 引言 前端程序猿主要关注的是页面,你可能根本就用不到.net,java,php等后台语言. 但是你制作出来的网页总要运行.总要测试吧?——那就免不了用到http server.我先前都是用vis ...

随机推荐

  1. CSS的display、hover、overflow、&copy(版权符号)、borer-radius(边框圆角)

    一.display: none 隐藏 block显示     visibility:hidden隐藏 visible显示 display:none和visibility:hidden这两个属性对应的值 ...

  2. 两种MD5最后的值不一样,因为两种做法不一样

    //MD5加密 private static string Md5Hash(string input)         {             MD5CryptoServiceProvider m ...

  3. YII2 Gridview

    YII2 Gridview 部分使用规则 1.页面显示的时间戳转换 a. [ 'label'=>'创建日期', 'attribute' => 'created_at', 'filter' ...

  4. leetcode 211. Add and Search Word - Data structure design Trie树

    题目链接 写一个数据结构, 支持两种操作. 加入一个字符串, 查找一个字符串是否存在.查找的时候, '.'可以代表任意一个字符. 显然是Trie树, 添加就是正常的添加, 查找的时候只要dfs查找就可 ...

  5. 浅谈Linux ftp服务器相关配置

    首先我们需要在Linux系统下安装FTP服务器  Ubuntu sudo apt-get install.......  centos yun....... 然后,我们要配置vsftpd.conf文件 ...

  6. 梳排序(Comb sort)

    Comb Sort,梳排序或者梳子排序,就像梳子那样有间隔地比较两个数,很形象,O(n*logn)时间复杂度,O(1)空间复杂度,属于不稳定的排序算法.算法的思想是使逆序的元素尽可能快地移动到最终的位 ...

  7. asp.net将object或string转为int

    在C#强制转换中,(int),Int32.Parse() 和 Convert.toInt32() 三种方法有何区别? int 关键字表示一种整型,是32位的,它的 .NET Framework 类型为 ...

  8. LINUX下使用crontab进行RMAN备份实验

    之前写了脚本,手动执行可以,使用crontab总是无法运行成功,今天下午花了两个小时实验,完成如下: 注意事项:脚本完成首先手动执行,确定可以正常执行. 在crontab中使用,要注意以下几点: 1. ...

  9. 修改MojoWeixin 只保留用户name 取消群昵称

    <pre name="code" class="python"> if($msg->type eq "friend_message& ...

  10. Uva 225 Golygons

    这道题如果直接用Dfs,运气好的话是可以直接过的. 但如果要在Dfs的基础上加快速度,剪枝是必不可少的. 我的剪枝策略: 1.当前点(x,y)回到出发点至少需要 |x| +| y| 步,如果剩余的步数 ...