zoukankan      html  css  js  c++  java
  • IOS详解TableView——内置刷新,EGO,以及搜索显示控制器

    这几天因为住的地方的网出了一点问题,除了能上Q,上微博以外其他的网页全都无法登陆。博客也就没有跟进。

    今天恢复了,所以继续更新博客。也希望大家能继续评论或私自给我一些建议或者交流:-)

    今天找到了以前一个TableView的例子,主要关于上下拉刷新的,所以写了一个demo,然后更新到博客上来。

    内置刷新

     
    内置刷新是苹果IOS6以后才推出的一个API,主要是针对TableViewController增加了一个属性,refreshControl,所以如果想用这个内置下拉刷新的话,最好给你的TableView指定一个专门的视图控制器了。
     
    使用的话,我们需要给refreshControl指定一个UIRefreshControl对象。跟进到头文件中看到
     
    三个属性,算上初始化三个方法,并不难,然后配置refreshControl

     

    设置了一个监听方法,来简单看下其实现

    因为这里并不是真正进行网络访问,所以这里用到了一个模拟网络访问延时的方法 dispatch_after 关于这个GCD方法并不难,只要设置延时时间和延时结束Block中的代码即可。
     
    可能注意到有个_bottomRefresh, 这个下面会用到,是一个底部“查看更多”的一个控件。
     
    先来看下现在的效果
     
    方法执行结束后我们会发现在TableView中Cell多了5行,这是刚才设置的_rowCount+5并刷新tableView产生的效果。
     
     

    自定义刷新

     
    在有些时候我们会看到TableView的最下方有一个标题为“查看更多”的按钮,有的可以响应向下滚动并且自动刷新,有的需要点击一下才会刷新,这里介绍一下点击响应刷新的一个实现方法。
     
    先看下效果
    我这里就使用了一个按钮,初始化到表视图的底部。
     
    由于默认的Button的标题稍微有点靠近最后一个Cell,所以设置了一下contentEdgeInsets属性。
     
    响应事件
     
    原理同上面下拉刷新的方法比较接近,这里为了显示加载网络效果,使用了一个第三方框架SVProgressHUD,关于HUD的具体使用就不介绍了,直接跟进头文件看方法就可知道。HUD还有许多开源框架,比如MBProgressHUD等。
     
    看下效果
     

    EGO刷新框架

     
    EGORefreshHeaderView刷新中,我们可以在初始化的时候设置两种样式,头部样式以及尾部尾部。设置代理,实现委托方法即可。
     
    这里只介绍头部刷新
     
     
    效果
    看下代理方法
     
    三个代理方法分别是返回刷新状态,返回刷新后显示的时间,以及刷新调用的方法。两个方法具体为
     
    要实现刷新效果,最后我们还要实现两个ScrollView的代理方法交给其处理
     
    效果就不贴图了,也是刷新后新增5个Cell
     
     

    搜索显示视图控制器的使用

    在这个项目的demo中,我是使用storyboard拉到了tableview中,所以很多属性自动配置好,不需要手工实现了。不过由于searchDisplayController有一个内置的搜索显示表视图,所以在对其进行管理上,需要视图控制器每次调用TableView代理方法时需要进行一下比较。

    同样cell也需要设置。那么这个_searchList的数据从哪里获得呢,通过实现UISearchDisplayController的代理方法即可

    这里用到了一个谓词(NSPredicate)类,谓词类似于苹果内置的SQL语句,对可以进行一些查询筛选等等。
    来看下搜索框使用的效果。
     
    响应表视图点击的方法也需要判断,然后根据需求实现。
     
     
     
    Demo源码:点击打开链接
     
     
    以上为本篇博客全部内容,欢迎指正和交流。转载注明出处~
  • 相关阅读:
    nginx 日志之 error_log
    ssl 原理简介
    nginx 配置ssl
    自建 ca 及使用 ca 颁发证书
    nginx 访问控制之 认证
    nginx 访问控制之 限速
    nginx 访问控制之 http_referer
    nginx 访问控制之 user_agent
    nginx 访问控制之 request_uri
    nginx 访问控制之 document_uri
  • 原文地址:https://www.cnblogs.com/BinShao/p/3553231.html
Copyright © 2011-2022 走看看