在IOS6未发布之前,几乎都是使用那个UIRefresh在实现下拉刷新,甚至有人还是先了上拉的功能,不得不说牛人很多啊。可能是Apple意识到了这个功能的实用性,在IOS6中增加了下拉刷新,但是上啦还没有添加。新手自学了一下这个下拉刷新的功能,还不错,分享一下。

首先看一下最终的效果:

       

注:我使用的是IOS6 SDK  + xCode4.5

一、新建一个工程,基于那么模板没关系,这里使用的是Single-view来实现的。

二、修改ViewController.h文件,由于Apple给出的下拉属性是在UITableViewController中,所以我们修改我们工程中的类继承UITableViewController。

使用command+鼠标点击UITableViewController,来到UITableViewController的定义处,我们可以看到如下部分:

在IOS6的版本中添加了UIRefreshControl,使用上面打开UITableViewController同样的方法,我们来到UIRefreshControl的定义处,可以看到如下的定义:

在UIRefreshControl中有几个使用的属性,我们即将使用到的是attributedTitle 属性。

查看完API之后,我们开始在ViewController.h文件中修改代码:

  1. #import <UIKit/UIKit.h>
  2. //修改父类为UITableViewController
  3. @interface UIRefreshViewController : UITableViewController
  4. //定义显示的个数
  5. @property (nonatomic,assign) NSInteger items;
  6. @end

注意这里不需要进行代理和数据源的书写,因为UITableViewController中已经对这两个内容进行了集成。

三、完成后在ViewController.m文件中初始化显示的个数,以及添加为UI添加刷新控件的方法。

  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. self.items = 0;
  5. [self addRefreshViewController];
  6. }



四、完成后实现这里的addRefreshViewController方法:

  1. -(void)addRefreshViewController{
  2. self.refreshControl = [[UIRefreshControl alloc] init];
  3. self.refreshControl.attributedTitle = [[NSAttributedString alloc] initWithString:@"下拉刷新"];
  4. [self.refreshControl addTarget:self action:@selector(RefreshViewControlEventValueChanged) forControlEvents:UIControlEventValueChanged];
  5. }

这里我们使用了attributedTitle属性,这个属性就是设置下拉刷新的文字显示的。另外,UIRefreshControl响应的是ValueChange事件。

五,当用户下拉table的时候,refreshControl就会响应RefreshViewControlEventValueChanged方法,在这个方法中实现下拉松开时所要显示的文字信息:

  1. -(void)RefreshViewControlEventValueChanged{
  2. self.refreshControl.attributedTitle = [[NSAttributedString alloc] initWithString:@"刷新中..."];
  3. [self performSelector:@selector(loadData) withObject:nil afterDelay:2.0f];
  4. }

这样在下拉的时候,refreshControl上的文字就会变成“刷新中。。。”,为了看到刷新的效果,设置了2秒的延后执行loadData,对用户来说是一个友好性,另外Apple的下拉还带有”粘性“类似的效果,蛮有意思。

六、编写loadData方法,实现界面数据的刷新。同时refreshControl置为”下拉刷新“状态。

  1. -(void)loadData{
  2. [self.refreshControl endRefreshing];
  3. self.refreshControl.attributedTitle = [[NSAttributedString alloc] initWithString:@"下拉刷新"];
  4. self.items++;
  5. [self.tableView reloadData];
  6. }



七、完成这些之后,还不能出现界面,需要我们实现TableView的那些delegate方法和dataSource方法:

  1. #pragma mark - Table view data source
  2. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
  3. {
  4. #warning Potentially incomplete method implementation.
  5. // Return the number of sections.
  6. return 1;
  7. }
  8. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
  9. {
  10. #warning Incomplete method implementation.
  11. // Return the number of rows in the section.
  12. return self.items;
  13. }
  14. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
  15. {
  16. static NSString *CellIdentifier = @"Cell";
  17. UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
  18. if (cell == nil) {
  19. cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];
  20. }
  21. // Configure the cell...
  22. cell.textLabel.text = [NSString stringWithFormat:@"Evolution.cc & %d",indexPath.row];
  23. return cell;
  24. }

八、完成后编译,确认无错误后,cmd+R运行,你就可以看到神奇的下拉刷新了。

IOS6新特性之下拉刷新<UIRefreshControl>的更多相关文章

  1. IOS6 新特性之UIRefreshControl

    "不会模仿的公司不是好公司不会剽窃的公司不是优秀公司  不会调戏代码的不是骨灰级码工 你同意吗? 苹果估计想取代第三方的pull to refresh"        ------ ...

  2. 【FastDev4Android框架开发】RecyclerView完全解析之下拉刷新与上拉加载SwipeRefreshLayout(三十一)

    转载请标明出处: http://blog.csdn.net/developer_jiangqq/article/details/49992269 本文出自:[江清清的博客] (一).前言: [好消息] ...

  3. 微信小程序之下拉刷新,上拉更多列表实现

    代码地址如下:http://www.demodashi.com/demo/11110.html 一.准备工作 首先需要下载小程序开发工具 官方下载地址: https://mp.weixin.qq.co ...

  4. android 5.0新特性学习总结之下拉刷新(一)

    android 5.0 后google最终在 support v4 包下 添加了下拉刷新的控件 项目地址: https://github.com/stormzhang/SwipeRefreshLayo ...

  5. Android之下拉刷新的ListView

    不废话,代码里面注释很详细,直接上代码: 自定义的RefreshableListView代码: public class RefreshableListView extends ListView im ...

  6. Xamarin.Android之下拉刷新

    一.前言 当今任何一个App中只要存在列表,基本上都会使用下拉刷新,而身为Xamarin一族的我们自然也不会落后,下面笔者将带领大家在Xamarin下实现Android中的下拉刷新的效果. 二.准备工 ...

  7. iOS学习之下拉刷新

    今天我们来给昨天的Demo加上下拉刷新和上拉加载更多的功能. 1.下拉刷新. 在viewDidLoad中调用方法addRefreshControl,下拉时可以出现风火轮加载更多的效果. - (void ...

  8. IOS6 新特性之UIActivityViewController详解

    新的IOS6增加了一些新特性.因为应用需要,所以在国庆的几天里.研究了一下IOS6的说明文档,然后大概地总结了一下UIActivityViewController的用法与大家分享. 首先 从实际效果入 ...

  9. Android之下拉刷新,上啦加载的实现(一)

    转载地址http://blog.csdn.net/leehong2005/article/details/12567757#t5 前段时间项目中用到了下拉刷新功能,之前在网上也找到过类似的demo,但 ...

随机推荐

  1. 编程写一个方法时,注意方法中传参数的数量最好不要超过5个,超过5个怎么办?可以用struct或class,或一个字典类

    图  1 一.从图1发现了什么问题呢? 答案:1.参数传的的太多了:2.另外注释也没写好. 说明:一个方法中,传参数的数量最好不要超过5个. 应该采用:struct或class,或一个字典类都行.其中 ...

  2. Heritrix3.x自定义扩展Extractor

    一.引言: Heritrix3.x与Heritrix1.x版本差异比较大,全新配置模式的引入+扩展接口的变化,同时由于说明文档的匮乏,给Heritrix的开发者带来困惑,前面的文章已经就Heritri ...

  3. HDFS高级开发培训课程之HDFS开发实例课件

    前言: 刚刚完成的HDFS高级开发培训课程课件中的一个章节,不知道PPT,如何导出HTML格式,只好批量导出图片,贴图了. 连接管理:建立连接.断开连接.设置连接参数 文件操作:浏览文件.上传文件.下 ...

  4. 夜神模拟器+seleinm抓取手机app(参考资料集合)

    目前准备开始实现这个技术,将看起来还算可靠的参考链接粘贴如下: http://www.cnblogs.com/puresoul/p/4597211.html https://www.cnblogs.c ...

  5. jstack可以定位到线程堆栈

    java命令--jstack 工具 JVM调优之jstack找出最耗cpu的线程并定位代码 jstack可以定位到线程堆栈,根据堆栈信息我们

  6. IE浏览器中overflow:hidden无效,内层元素超出外层div的解决方法

    原文地址:http://www.xin126.cn/show.asp?id=2624 在用css布局的时候,用IE浏览器(ie6.ie7.ie8)预览,有时候会出现内层元素(内部DIV.图片等)超出外 ...

  7. 1012 The Best Rank (25 分)

    1012 The Best Rank (25 分) To evaluate the performance of our first year CS majored students, we cons ...

  8. maven package 命令报:-source1.3 中不支持注释错误

    在使用maven 打包或者编译时报:-source1.3 中不支持注释错误解决方案如下: <build>  <plugins>   <plugin>    < ...

  9. decorator的class方式

    class式的 Decorator decorator的class方式 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 clas ...

  10. eventql操作脚本

    a) standalone mode mkdir -p /var/evql/standalone/usr/local/bin/evqld --standalone --datadir /var/evq ...