iOS开发-ios7下拉刷新,上提加载快速集成

简介: <div id="article_details" class="details" style="margin:20px; color:rgb(51,51,51); font-family:Arial,Console,Verdana,'Courier New'"> <div id="article_content" class="article_content" style="margi

在ios7之前,一直在使用开源的EGO库。但是,在使用过程中发现,普遍封装得过于复杂、耦合性强,不利于集成到自己的项目中。

另外,在ios7之后,一些原有的下拉刷新,上提加载控件表现的就不是那么出色了。除了可能出错外,也不符合扁平化的风格。

后来,在code4App上发现了一个大牛上传了一个开源代码, 仅需几行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能。可以自定义上下拉刷新的文字说明。

下载下来自己试了下,发现不错。  mark下。

下载链接:http://code4app.com/ios/快速集成下拉上拉刷新/52326ce26803fabc46000000


下面纪录下自己的集成过程,当然,作者所给的demo里面已经很详细的给出了。 这里只不过是纪录下自己的实现过程而已。


1.将MJRefresh文件夹整个导入所需的工程中。

2.文件夹中的MJRefresh.bundle--->arrow@2x.png 图片可自行替换,这个会在刷新过程中显示。

3.可以在MJRefreshConst.h和MJRefreshConst.m文件中自定义显示的文字内容和文字颜色。

4.只要你的view能够滚动,就能集成这个控件,比如UIScrollView、UITableView、UICollectionView

5.在需要使用的地方,加入如下代码即可。

5.1  导入头文件

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. #import "MJRefresh.h"  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. #import "MJRefresh.h"  

5.2  遵从协议

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. @interface ViewController ()<MJRefreshBaseViewDelegate>  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. @interface ViewController ()<MJRefreshBaseViewDelegate>  

5.3  为你的view添加控件

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. MJRefreshFooterView *footer = [MJRefreshFooterView footer];  
  2.     footer.scrollView = myTableView;  
  3.     footer.delegate = self;  
  4.       
  5.     MJRefreshHeaderView *header = [MJRefreshHeaderView header];  
  6.     header.scrollView = myTableView;  
  7.     header.delegate = self;  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. MJRefreshFooterView *footer = [MJRefreshFooterView footer];  
  2.     footer.scrollView = myTableView;  
  3.     footer.delegate = self;  
  4.       
  5.     MJRefreshHeaderView *header = [MJRefreshHeaderView header];  
  6.     header.scrollView = myTableView;  
  7.     header.delegate = self;  

5.4实现代理方法

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. #pragma mark - 刷新控件的代理方法  
  2. #pragma mark 开始进入刷新状态  
  3. - (void)refreshViewBeginRefreshing:(MJRefreshBaseView *)refreshView  
  4. {  
  5.     NSLog(@"%@----开始进入刷新状态", refreshView.class);  
  6.     // 2.2秒后刷新表格UI  
  7.     [self performSelector:@selector(doneWithView:) withObject:refreshView afterDelay:2.0];  
  8.   
  9. }  
  10.   
  11. #pragma mark 刷新完毕  
  12. - (void)refreshViewEndRefreshing:(MJRefreshBaseView *)refreshView  
  13. {  
  14.     NSLog(@"%@----刷新完毕", refreshView.class);  
  15. }  
  16.   
  17. #pragma mark 监听刷新状态的改变  
  18. - (void)refreshView:(MJRefreshBaseView *)refreshView stateChange:(MJRefreshState)state  
  19. {  
  20.     switch (state) {  
  21.         case MJRefreshStateNormal:  
  22.             NSLog(@"%@----切换到:普通状态", refreshView.class);  
  23.             break;  
  24.               
  25.         case MJRefreshStatePulling:  
  26.             NSLog(@"%@----切换到:松开即可刷新的状态", refreshView.class);  
  27.             break;  
  28.               
  29.         case MJRefreshStateRefreshing:  
  30.             NSLog(@"%@----切换到:正在刷新状态", refreshView.class);  
  31.             break;  
  32.         default:  
  33.             break;  
  34.     }  
  35. }  
  36.   
  37. #pragma mark 刷新表格并且结束正在刷新状态  
  38. - (void)doneWithView:(MJRefreshBaseView *)refreshView  
  39. {  
  40.     // 刷新表格  
  41.     [myTableView reloadData];  
  42.       
  43.     // (最好在刷新表格后调用)调用endRefreshing可以结束刷新状态  
  44.     [refreshView endRefreshing];  
  45. }  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. #pragma mark - 刷新控件的代理方法  
  2. #pragma mark 开始进入刷新状态  
  3. - (void)refreshViewBeginRefreshing:(MJRefreshBaseView *)refreshView  
  4. {  
  5.     NSLog(@"%@----开始进入刷新状态", refreshView.class);  
  6.     // 2.2秒后刷新表格UI  
  7.     [self performSelector:@selector(doneWithView:) withObject:refreshView afterDelay:2.0];  
  8.   
  9. }  
  10.   
  11. #pragma mark 刷新完毕  
  12. - (void)refreshViewEndRefreshing:(MJRefreshBaseView *)refreshView  
  13. {  
  14.     NSLog(@"%@----刷新完毕", refreshView.class);  
  15. }  
  16.   
  17. #pragma mark 监听刷新状态的改变  
  18. - (void)refreshView:(MJRefreshBaseView *)refreshView stateChange:(MJRefreshState)state  
  19. {  
  20.     switch (state) {  
  21.         case MJRefreshStateNormal:  
  22.             NSLog(@"%@----切换到:普通状态", refreshView.class);  
  23.             break;  
  24.               
  25.         case MJRefreshStatePulling:  
  26.             NSLog(@"%@----切换到:松开即可刷新的状态", refreshView.class);  
  27.             break;  
  28.               
  29.         case MJRefreshStateRefreshing:  
  30.             NSLog(@"%@----切换到:正在刷新状态", refreshView.class);  
  31.             break;  
  32.         default:  
  33.             break;  
  34.     }  
  35. }  
  36.   
  37. #pragma mark 刷新表格并且结束正在刷新状态  
  38. - (void)doneWithView:(MJRefreshBaseView *)refreshView  
  39. {  
  40.     // 刷新表格  
  41.     [myTableView reloadData];  
  42.       
  43.     // (最好在刷新表格后调用)调用endRefreshing可以结束刷新状态  
  44.     [refreshView endRefreshing];  
  45. }  


6.你可以通过调用beginRefreshing自动进入下拉刷新状态。

7.你可以通过调用endRefreshing结束刷新状态。

8.为了保证内部不泄露,最好在控制器的dealloc中释放占用的内存
- (void)dealloc
{
[_header free];
[_footer free];
}


效果图:
  • iOS / iPhone / iPad 仅需几行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能。可以自定义上下拉刷新的文字说明。具体使用看下面的“使用方法”。<br /><br />    2014.02.08版本代码更新功能:<br /><br />    1.修复了“没有数据时,上拉加载更多控件停滞不下”的BUG;<br /><br />    2.修复了示例程序中控制器的内存泄露。<br /><br />    2014.01.03版本代码更新功能:<br /><br />    1.完美适配iOS6\iOS7、iPhone\iPad横竖屏<br /><br />    2.增加了刷新控件状态改变的回调机制<br /><br />    3.解决了上拉加载更多残留已久的莫名其妙BUG,增强了用户体验<br /><br />    4.删除了冗余的音频播放功能<br /><br />    5.增加了内存释放功能,解决了内存泄露的BUG<br /><br />    2013.01.03版本代码更新功能:<br /><br />    1.适配iPhone横竖屏、iPad横竖屏;<br /><br />    2.不用再调用 free 方法来释放刷新控件的资源;<br /><br />    3.演示了刷新控件的block回调;<br /><br />    4.演示了刷新控件在UICollectionView上的使用.<br /><br />    作者说:网上开源的下拉-上拉刷新控件,普遍封装得过于复杂、耦合性强。因此本人特地花了点时间写了一套无耦合、可插拔式的刷新控件,对项目中的其他代码毫无侵入性,而且使用简单,3行代码就能集成刷新控件。<br /><br />    小编注:感谢开发者@M了个J 发布代码于Code4App.com。
  • iOS / iPhone / iPad 仅需几行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能。可以自定义上下拉刷新的文字说明。具体使用看下面的“使用方法”。<br /><br />    2014.02.08版本代码更新功能:<br /><br />    1.修复了“没有数据时,上拉加载更多控件停滞不下”的BUG;<br /><br />    2.修复了示例程序中控制器的内存泄露。<br /><br />    2014.01.03版本代码更新功能:<br /><br />    1.完美适配iOS6\iOS7、iPhone\iPad横竖屏<br /><br />    2.增加了刷新控件状态改变的回调机制<br /><br />    3.解决了上拉加载更多残留已久的莫名其妙BUG,增强了用户体验<br /><br />    4.删除了冗余的音频播放功能<br /><br />    5.增加了内存释放功能,解决了内存泄露的BUG<br /><br />    2013.01.03版本代码更新功能:<br /><br />    1.适配iPhone横竖屏、iPad横竖屏;<br /><br />    2.不用再调用 free 方法来释放刷新控件的资源;<br /><br />    3.演示了刷新控件的block回调;<br /><br />    4.演示了刷新控件在UICollectionView上的使用.<br /><br />    作者说:网上开源的下拉-上拉刷新控件,普遍封装得过于复杂、耦合性强。因此本人特地花了点时间写了一套无耦合、可插拔式的刷新控件,对项目中的其他代码毫无侵入性,而且使用简单,3行代码就能集成刷新控件。<br /><br />    小编注:感谢开发者@M了个J 发布代码于Code4App.com。
  • iOS / iPhone / iPad 仅需几行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能。可以自定义上下拉刷新的文字说明。具体使用看下面的“使用方法”。<br /><br />    2014.02.08版本代码更新功能:<br /><br />    1.修复了“没有数据时,上拉加载更多控件停滞不下”的BUG;<br /><br />    2.修复了示例程序中控制器的内存泄露。<br /><br />    2014.01.03版本代码更新功能:<br /><br />    1.完美适配iOS6\iOS7、iPhone\iPad横竖屏<br /><br />    2.增加了刷新控件状态改变的回调机制<br /><br />    3.解决了上拉加载更多残留已久的莫名其妙BUG,增强了用户体验<br /><br />    4.删除了冗余的音频播放功能<br /><br />    5.增加了内存释放功能,解决了内存泄露的BUG<br /><br />    2013.01.03版本代码更新功能:<br /><br />    1.适配iPhone横竖屏、iPad横竖屏;<br /><br />    2.不用再调用 free 方法来释放刷新控件的资源;<br /><br />    3.演示了刷新控件的block回调;<br /><br />    4.演示了刷新控件在UICollectionView上的使用.<br /><br />    作者说:网上开源的下拉-上拉刷新控件,普遍封装得过于复杂、耦合性强。因此本人特地花了点时间写了一套无耦合、可插拔式的刷新控件,对项目中的其他代码毫无侵入性,而且使用简单,3行代码就能集成刷新控件。<br /><br />    小编注:感谢开发者@M了个J 发布代码于Code4App.com。
  • iOS / iPhone / iPad 仅需几行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能。可以自定义上下拉刷新的文字说明。具体使用看下面的“使用方法”。<br /><br />    2014.02.08版本代码更新功能:<br /><br />    1.修复了“没有数据时,上拉加载更多控件停滞不下”的BUG;<br /><br />    2.修复了示例程序中控制器的内存泄露。<br /><br />    2014.01.03版本代码更新功能:<br /><br />    1.完美适配iOS6\iOS7、iPhone\iPad横竖屏<br /><br />    2.增加了刷新控件状态改变的回调机制<br /><br />    3.解决了上拉加载更多残留已久的莫名其妙BUG,增强了用户体验<br /><br />    4.删除了冗余的音频播放功能<br /><br />    5.增加了内存释放功能,解决了内存泄露的BUG<br /><br />    2013.01.03版本代码更新功能:<br /><br />    1.适配iPhone横竖屏、iPad横竖屏;<br /><br />    2.不用再调用 free 方法来释放刷新控件的资源;<br /><br />    3.演示了刷新控件的block回调;<br /><br />    4.演示了刷新控件在UICollectionView上的使用.<br /><br />    作者说:网上开源的下拉-上拉刷新控件,普遍封装得过于复杂、耦合性强。因此本人特地花了点时间写了一套无耦合、可插拔式的刷新控件,对项目中的其他代码毫无侵入性,而且使用简单,3行代码就能集成刷新控件。<br /><br />    小编注:感谢开发者@M了个J 发布代码于Code4App.com。
目录
相关文章
|
JavaScript 前端开发 持续交付
Prettier 高级应用:集成 CI/CD 流水线与插件开发
【10月更文挑战第18天】Prettier 是一款流行的代码格式化工具,它能够自动将代码格式化成一致的风格,从而提高代码的可读性和维护性。对于希望进一步发挥 Prettier 潜力的高级用户而言,将 Prettier 集成到持续集成(CI)和持续部署(CD)流程中,确保每次提交的代码都符合团队标准,是非常重要的。此外,通过开发自定义插件来支持更多语言或扩展 Prettier 的功能也是值得探索的方向。本文将详细介绍这两方面的内容。
264 2
|
2月前
|
XML 测试技术 API
利用C#开发ONVIF客户端和集成RTSP播放功能
利用C#开发ONVIF客户端和集成RTSP播放功能
1314 123
|
4月前
|
数据采集 运维 DataWorks
DataWorks 千万级任务调度与全链路集成开发治理赋能智能驾驶技术突破
智能驾驶数据预处理面临数据孤岛、任务爆炸与开发运维一体化三大挑战。DataWorks提供一站式的解决方案,支持千万级任务调度、多源数据集成及全链路数据开发,助力智能驾驶模型数据处理与模型训练高效落地。
|
7月前
|
监控 Java API
1K star!这个开源项目让短信集成简单到离谱,开发效率直接翻倍!
SMS4J 是一款由国内技术团队打造的短信聚合框架,专为解决多短信服务商接入难题而生。它就像短信界的"瑞士军刀",目前已整合21家主流短信服务商,从阿里云、腾讯云到中国移动云MAS,开发者只需通过简单配置即可实现多平台无缝切换。
447 4
|
9月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
584 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
5月前
|
监控 安全 Java
Java 开发中基于 Spring Boot 3.2 框架集成 MQTT 5.0 协议实现消息推送与订阅功能的技术方案解析
本文介绍基于Spring Boot 3.2集成MQTT 5.0的消息推送与订阅技术方案,涵盖核心技术栈选型(Spring Boot、Eclipse Paho、HiveMQ)、项目搭建与配置、消息发布与订阅服务实现,以及在智能家居控制系统中的应用实例。同时,详细探讨了安全增强(TLS/SSL)、性能优化(异步处理与背压控制)、测试监控及生产环境部署方案,为构建高可用、高性能的消息通信系统提供全面指导。附资源下载链接:[https://pan.quark.cn/s/14fcf913bae6](https://pan.quark.cn/s/14fcf913bae6)。
908 0
|
7月前
|
人工智能 程序员 测试技术
通义灵码与魔搭 Notebook 深度集成:在线编码开箱即用,开发效率倍增
通义灵码 2.0 AI 程序员 2025 年 1 月正式上线,目前已经服务百万开发者,成为国内开发者最受欢迎的智能编码助手。
|
7月前
|
人工智能 IDE 测试技术
通义灵码与魔搭Notebook深度集成:在线编码开箱即用,开发效率倍增
通义灵码2.0 AI程序员于2025年1月上线,目前已支持超过百万开发者。该工具的智能编程能力现已与阿里云AI模型开发平台魔搭ModelScope实现技术集成
318 0
|
12月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
301 2
|
12月前
|
传感器 前端开发 Android开发
在 Flutter 开发中,插件开发与集成至关重要,它能扩展应用功能,满足复杂业务需求
在 Flutter 开发中,插件开发与集成至关重要,它能扩展应用功能,满足复杂业务需求。本文深入探讨了插件开发的基本概念、流程、集成方法、常见类型及开发实例,如相机插件的开发步骤,同时强调了版本兼容性、性能优化等注意事项,并展望了插件开发的未来趋势。
321 2