1.运行效果图

2.swift 代码的实现

import UIKit

class RefreshWebViewController: UIViewController,UIScrollViewDelegate,UIWebViewDelegate{

@IBOutlet weak var webView: UIWebView!

//刷新控件view

private var header:UIView!

//下拉到50时松开刷新

private let pullHeight:CGFloat=50

//刷新提示文字

private var headerText:UILabel!

//刷新指示器(旋转小圆圈)

private var activityView:UIActivityIndicatorView!

//标记刷新状态

private var isRefreshing=false

override func viewDidLoad() {

super.viewDidLoad()

self.webView.scrollView.delegate=self

self.webView.delegate=self

self.automaticallyAdjustsScrollViewInsets=false

initHeaderView()

loading()

}

//定义下拉刷新控件

private func initHeaderView( )  {

self.header=UIView(frame: CGRectMake(0,0, self.view.frame.width,200))

self.header.backgroundColor=UIColor.darkGrayColor()

self.headerText=UILabel(frame: CGRectMake((self.view.frame.width-120)/2,10,150,30))

self.headerText.text="下拉刷新"

self.headerText.textAlignment=NSTextAlignment.Center

self.headerText.textColor=UIColor.whiteColor()

self.header.addSubview(headerText)

self.activityView=UIActivityIndicatorView(frame: CGRectMake( self.headerText.frame.origin.x-5,15,20,20))

self.header.addSubview(activityView)

self.webView.insertSubview(header, atIndex: 0)

}

//加载网页

func loading( ) {

self.webView.loadRequest(NSURLRequest(URL: NSURL(string:"http://www.hao123.com")!))

}

//scroll滚动时调用

func scrollViewDidScroll(scrollView: UIScrollView) {

if isRefreshing{

return

}

//当下拉到pullHeight高度时松开即可刷新

if scrollView.contentOffset.y <= -pullHeight{

self.headerText.text="松开立即刷新"

}else{

self.headerText.text="下拉刷新"

}

}

//    scrollview停止滚动时调用

func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {

if isRefreshing{

return

}

if scrollView.contentOffset.y <= -pullHeight{

refreshing()

}

}

//开始刷新

func refreshing( )   {

isRefreshing=true

self.headerText.text="正在刷新..."

self.activityView.startAnimating()

UIView.animateWithDuration(0.5, delay: 0,   options: .CurveEaseOut, animations: {

// 设置刷新控件停留

var offY = self.webView.scrollView.contentInset

offY.top += self.pullHeight

self.webView.scrollView.contentInset=offY

}, completion:{(_)->Void in

})

self.loading()

}

//刷新结束

func refreshEnd() {

self.headerText.text="刷新成功"

self.activityView.stopAnimating()

UIView.animateWithDuration(1, delay: 0,   options: .CurveEaseOut, animations: {

//恢复刷新控件到原始位置

var offY = self.webView.scrollView.contentInset

offY.top -= self.pullHeight

self.webView.scrollView.contentInset=offY

}, completion:{(_)->Void in

self.isRefreshing=false

self.headerText.text="下拉刷新"

})

}

//网页加载完成

func webViewDidFinishLoad(webView: UIWebView) {

if isRefreshing{

refreshEnd()

}

}

}

IOS UIWebView 下拉刷新功能的简单实现的更多相关文章

  1. 原生js实现简单的下拉刷新功能

    前言: 我们在浏览移动端web页面的时候,经常会用到下拉刷新. 现在我们用原生的js实现这个非常简单的下拉刷新功能. (温馨提示:本文比较基础,功能也很简单.写的不好的地方,希望大神提点一二.) 一. ...

  2. Xamarin. Android实现下拉刷新功能

    PS:发现文章被其他网站或者博客抓取后发表为原创了,给图片加了个水印 下拉刷新功能在安卓和iOS中非常常见,一般实现这样的功能都是直接使用第三方的库,网上能找到很多这样的开源库.然而在Xamarin. ...

  3. Android 高仿微信(QQ)滑动弹出编辑、删除菜单效果,增加下拉刷新功能

    不可否认,微信.QQ列表的滑动删除.编辑功能着实很经典(从IOS那边模仿过来的),然.Android这边,对列表的操作,其实大多还停留上下文菜单来实现. Android如何实现list item的滑动 ...

  4. IOS 开发下拉刷新和上拉加载更多

    IOS 开发下拉刷新和上拉加载更多 简介 1.常用的下拉刷新的实现方式 (1)UIRefreshControl (2)EGOTTableViewrefresh (3)AH3DPullRefresh ( ...

  5. [转]Android下拉刷新完全解析,教你如何一分钟实现下拉刷新功能

    版权声明:本文出自郭霖的博客,转载必须注明出处. 转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最近项目中需要用到L ...

  6. Android下拉刷新完全解析,教你如何一分钟实现下拉刷新功能 (转)

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最 近项目中需要用到ListView下拉刷新的功能,一开始想图省事,在 ...

  7. android ListView上拉加载更多 下拉刷新功能实现(采用pull-to-refresh)

    Android实现上拉加载更多功能以及下拉刷新功能, 采用了目前比较火的PullToRefresh,他是目前实现比较好的下拉刷新的类库. 目前他支持的控件有:ListView, ExpandableL ...

  8. 利用Swiperefreshlayout实现下拉刷新功能的技术探讨

    在常见的APP中通常有着下拉页面从而达到刷新页面的功能,这种看似简单的功能有着花样繁多的实现方式.而利用Swiperefreshlayout实现下拉刷新功能则是其中比较简明扼要的一种. 一般来说,在竖 ...

  9. Android StaggeredGrid 加下拉刷新功能 PullToRefresh

    https://github.com/etsy/AndroidStaggeredGrid  用的github上面提供瀑布流,继承于abslistview,回收机制不错,并且提供了OnScrollLis ...

随机推荐

  1. 原生JS实现购物车结算功能代码+zepto版

    html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  2. flask_sqlalchemy 命名遇到的一个小坑

    大概用了三个小时的时间. models.py class DriveRecord(db.Model): """drive record model"" ...

  3. VC++/MFC 最常用宏和指令

    1.#include指令  包含指定的文件,最基本的最熟悉的指令,编程中不得不用,包含库文件用双尖括号,包含自定义头文件用双引号. 2.#define指令   预定义,通常用它来定义常量(包括无参量与 ...

  4. maven项目断点依赖maven插件

         

  5. $.extend()、$.fn和$.fn.extend()

      理解$.extend().$.fn和$.fn.extend()   原文链接:http://caibaojian.com/jquery-extend-and-jquery-fn-extend.ht ...

  6. WPF如何控制每个窗体确保只打开一次

    在主窗体上点击菜单时,如果做到每个窗体不会被重复打开,如果打开了,可以将其重新获得焦点. 首先在主窗体中将菜单关联的窗体实例化. 第二步:将每个菜单对应窗体的closing事件重写.之所以要重写clo ...

  7. 虚拟机出现“操作文件.PhysicalDrive1失败”的解决方法

    今天打算利用U盘给虚拟机装系统做实验,中途遇到了"操作文件.PhysicalDrive1失败"的错误,试了网上的方法都没有成功,最后自己试了很久总算弄出来了.鉴于本人的基础水平有限 ...

  8. 【转】arm 开发工具比较(ADS vs RealviewMDK vs RVDS)

      ADS REALVIEW MDK RVDS 公司 ARM Keil(后被ARM收购) ARM 版本 最新1.2 ,被RVDS取代 最新4.0 是否免费 破解情况 有 有 工程管理 CodeWarr ...

  9. python笔记:windows 下安装 python lxml

    原文:http://blog.csdn.net/zhaokuo719/article/details/8209496 windows 环境下安装 lxml python 1.首先保证你的python ...

  10. 手把手教你玩转nginx负载均衡(一)----使用vitualBox创建虚拟机

    引言 作为一个web程序员,有时候需要想尽办法来利用有限的资源来产生最大程度的负载,除了提高硬件配置,增加带宽之外,CDN加速,DNS加速,缓存,还可以利用反向代理.但是要说反向代理,就不的不说ngi ...