IOS UIWebView 下拉刷新功能的简单实现

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()

}

}

}

时间: 2024-12-31 03:11:53

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

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

前言: 我们在浏览移动端web页面的时候,经常会用到下拉刷新. 现在我们用原生的js实现这个非常简单的下拉刷新功能. (温馨提示:本文比较基础,功能也很简单.写的不好的地方,希望大神提点一二.) 一.创建简单的html页面: 假设代码里的float-box是一个主页面. 二.封装下拉刷新的功能模块: (1)首先创建一个Slide构造函数,用来初始化属性与函数. function Slide(dom){ this.start_y=null;//手指滑动屏幕的初始位置 this.end_y=null

Xamarin. Android实现下拉刷新功能

下拉刷新功能在安卓和iOS中非常常见,一般实现这样的功能都是直接使用第三方的库,网上能找到很多这样的开源库.然而在Xamarin. Android中要实现一个好用的下拉刷新功能却不是很容易,在网上找了几个Xamarin.Android的下拉刷新控件,都不是很满意,所以想重新绑定一个java写的下拉刷新控件.在网上找了几个这样的开源库,通过对比发现android-pull-to-refresh实现的功能比较多,实现的效果也比较满意. Android-Pull-To-Refresh项目地址:http

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

Android实现上拉加载更多功能以及下拉刷新功能, 采用了目前比较火的PullToRefresh,他是目前实现比较好的下拉刷新的类库. 目前他支持的控件有:ListView, ExpandableListView,GridView,WebView等. 下载地址:https://github.com/chrisbanes/Android-PullToRefresh 首先第一步当然是导入libriay到咱们的项目了,具体导入方式,这里不再赘述. 下面是个例子采用的是ListView,当然其余的和这

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

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最近项目中需要用到ListView下拉刷新的功能,一开始想图省事,在网上直接找一个现成的,可是尝试了网上多个版本的下拉刷新之后发现效果都不怎么理想.有些是因为功能不完整或有Bug,有些是因为使用起来太复杂,十全十美的还真没找到.因此我也是放弃了在网上找现成代码的想法,自己花功夫编写了一种非常简单的下拉刷新实现方案,现在拿出来和大家分享一下.相信在阅读完本篇文章之后,大

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

IOS 开发下拉刷新和上拉加载更多 简介 1.常用的下拉刷新的实现方式 (1)UIRefreshControl (2)EGOTTableViewrefresh (3)AH3DPullRefresh (4)MJRefresh (5)自己实现 2.AH3DPullRefresh实现下拉刷新和上拉下载的步骤 添加UIScrollView+AH3DPullRefresh.h 和UIScrollView+AH3DPullRefresh.m两个文件,由此可知,它是基于UIScrollView的方法. 在bu

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

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最近项目中需要用到ListView下拉刷新的功能,一开始想图省事,在网上直接找一个现成的,可是尝试了网上多个版本的下拉刷新之后发现效果都不怎么理想.有些是因为功能不完整或有Bug,有些是因为使用起来太复杂,十全十美的还真没找到.因此我也是放弃了在网上找现成代码的想法,自己花功夫编写了一种非常简单的下拉刷新实现方案,现在拿出来和大家分享一下.相信在阅读完本篇文章之后,大

android官方自带下拉刷新功能

最近想写下拉刷新功能,网上找的第三方框架最著名的pullToRefresh也早在2013年停止维护了,偶然间发现谷歌公司早已推出了自家的下拉刷新功能,位于v4包中,效果请看下图: 使用的就是android.support.v4.widget.SwipeRefreshLayout控件,使用方法也很简单,首先把需要下拉刷新的listView放入SwipeRefreshLayout中,代码如下: xml布局: <android.support.v4.widget.SwipeRefreshLayout

使用google自带包实现下拉刷新功能

android 实现下拉刷新有很多开源的源码可以用 比如 :PullToRefreshListView  使用起来也很方便 现在还可以直接使用google libs下面的 android-support-v4.jar 这个包来实现了,请更新你的sdk到最新 使用 xml 布局 <android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"

Android实战简易教程-第五十四枪(通过实现OnScrollListener接口实现下拉刷新功能)

上一篇文章Android实战简易教程-第五十三枪(通过实现OnScrollListener接口实现上拉加载更多功能)讲述了如何实现上拉加载更多的功能,本篇,我们在上一篇的基础上实现下拉刷新功能.主要通过对滚动状态和手势监听实现这一功能,下面我们看一下代码: 1.header.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://sch