jquery iscroll仿原生app下拉和上拉刷新

关于iscroll插件

iscroll插件(官网地址)当前最新的版本是version 5版本,相对于版本4,我个人觉得,版本5变得更具有灵活性,虽然移除了一些特定的事件,特定的对外接口,但是对于使用该插件的程序员们,这个插件变得更具有操控性,这是我比较喜欢的一种插件类型,但同时,也发现了一些问题,事件中的touchend事件,不存在了(确切的说,不能说是不存在),只是被拦截了,所以一些基本的事件,都被进行了拦截,而导致无法监听到touchend事件,只能检测到scrollEnd事件,scrollEnd事件,是在页面滚动停止时,才会被触发的,所以~~

所以,根据版本5,无法检测到,是不是下拉了一段距离之后,松开时的动作了,对此,我也检查了源代码,也没有发现这个功能的实现方法,不得已,只能对源代码进行了少量的修改,所以就有了本篇文章。

修改后插件的使用

基本上,该方法并没有进行多少的修改,只是添加了两个事件的监听类型,一个叫做“slideDown”,表示下拉被触发,另一个叫做“slideUp”,表示上拉被触发。

其他,实例化中,各属性都没有进行更改,所以,关于iscroll的使用,直接参考官网的说明:iscroll官网。

这里,我只对新添加的事件,添加一个demo测试,这个demo是一个很简单的demo,也只是用来说明新添加事件的用法的,如果需要用到下拉刷新或者上拉刷新的朋友,可以根据本demo自行修改。

html代码

 代码如下 复制代码

<div id="wrapper">
    <div id="scroller">
        <div id="scroller-pullDown">
            <span id="down-icon" class="icon-double-angle-down pull-down-icon"><img src="./images/loading.gif"></span>
            <span id="pullDown-msg" class="pull-down-msg">下拉刷新</span>
        </div>
        <div id="scroller-content">
            <ul class="list">
                <li>demo1</li>
                <li>demo1</li>
                <li>demo1</li>
                <li>demo1</li>
                <li>demo1</li>
                <li>demo1</li>
                <li>demo1</li>
            </ul>
        </div>
        <div id="scroller-pullUp">
            <span id="up-icon" class="icon-double-angle-up pull-up-icon"><img src="./images/loading.gif"></span>
            <span id="pullUp-msg" class="pull-up-msg">上拉刷新</span>
        </div>
    </div>
</div>

js代码

 代码如下 复制代码

$(function(){ 
    var myScroll, 
        upIcon = $("#up-icon"), 
        downIcon = $("#down-icon") 
        target = $(".list"), 
        temp = " "; 
         
    myScroll = new IScroll('#wrapper', { probeType: 3, mouseWheel: true });//probeType属性,表明此插件,可以监听scroll事件 
     
    myScroll.on("scroll",function(){ 
        //scroll事件,可以用来控制上拉和下拉之后显示的模块中, 
        //样式和内容展示的部分的改变。 
        var y = this.y, 
            maxY = this.maxScrollY - y, 
            downHasClass = downIcon.hasClass("reverse_icon"), 
            upHasClass = upIcon.hasClass("reverse_icon"); 
         
        if(y >= 40){ 
            !downHasClass && downIcon.addClass("reverse_icon"); 
            return ""; 
        }else if(y < 40 && y > 0){ 
            downHasClass && downIcon.removeClass("reverse_icon"); 
            return ""; 
        } 
         
        if(maxY >= 40){ 
            !upHasClass && upIcon.addClass("reverse_icon"); 
            return ""; 
        }else if(maxY < 40 && maxY >=0){ 
            upHasClass && upIcon.removeClass("reverse_icon"); 
            return ""; 
        } 
    }); 
     
    myScroll.on("slideDown",function(){ 
        //当下拉,使得边界超出时,如果手指从屏幕移开,则会触发该事件 
        if(this.y > 40){ 
            //获取内容于屏幕拉开的距离 
            //可以在该部分中,修改样式,并且仅限ajax或者其他的一些操作 
            //此时只是为了能演示该功能,只添加了一个alert功能。 
            //并且,由于alert会阻塞后续的动画效果,所以, 
            //添加了后面的一行代码,移除之前添加上的一个样式 
            //alert("slideDown"); 
            //upIcon.removeClass("reverse_icon") 
            temp='<li>我是新加进来的</li>\ 
            <li>我是新加进来的</li>'; 
            target.before(temp); 
            myScroll.refresh(); 
        } 
    }); 
     
    myScroll.on("slideUp",function(){ 
        if(this.maxScrollY - this.y > 40){ 
            //与slideDown相同的,maxScrollY表示文档区域的最大高度 
            //alert("slideUp"); 
            //upIcon.removeClass("reverse_icon") 
            temp='<li>我是新加进来的</li>\ 
            <li>我是新加进来的</li>'; 
            target.append(temp); 
            myScroll.refresh(); 
        } 
    }); 
}) 

css代码我就不贴出来了,看demo里,很简单了。

最后,注意一点,当你使用ajax添加或者删除一些新的元素时,要重新myScroll.refresh()一下,会重新计算maxScrollY区域的,以保证区域覆盖的正确性,这些东西,如果你真的使用到,那么肯定可以碰到这些问题的,所以,这里是我话多了~~~

时间: 2024-09-22 05:52:36

jquery iscroll仿原生app下拉和上拉刷新的相关文章

简单易用的基于jQuery版仿新浪微博向下滚动效果(附DEMO)_jquery

甜蜜情人节给点力--合肥网2011情人节.情人周11大钜献_合肥网专题 - 专题频道-合肥网 甜蜜情人节给点力--合肥网2011情人节.情人周11大钜献_合肥网专题 - 专题频道-合肥网甜蜜情人节给点力--合肥网2011情人节.情人周11大钜献_合肥网专题 - 专题频道-合肥网 甜蜜情人节给点力--合肥网2011情人节.情人周11大钜献_合肥网专题 - 专题频道-合肥网甜蜜情人节给点力--合肥网2011情人节.情人周11大钜献_合肥网专题 - 专题频道-合肥网甜蜜情人节给点力--合肥网2011情

基于iscroll.js实现下拉刷新和上拉加载效果_javascript技巧

现在已经不是纯Android独霸天下的时代了,H5嵌入Android的Hybrid混合开发是大势所趋.今天给大家带来的就是移动端中常见的"上拉刷新,下拉加载"特效,这个特效将会基于H5来实现. 先看下运行效果: 是不是有点小小的'鸡冻' ,它就是由我们今天要介绍的主人公'iscroll.js'实现的,接下来我以最最简便的方式教给大家~~ 实现步骤 一.准备好iscroll.js库 到官网下载即可: https://github.com/cubiq/iscroll 二.搭建页面结构 &l

Android程序开发之使用PullToRefresh实现下拉刷新和上拉加载

PullToRefresh是一套实现非常好的下拉刷新库,它支持: 1.ListView 2.ExpandableListView 3.GridView 4.WebView 等多种常用的需要刷新的View类型,而且使用起来也十分方便. (下载地址:https://github.com/chrisbanes/Android-PullToRefresh) 下载完成,将它导入到eclipse中,作为一个library导入到你的工程中就好了. 一.废话少说,下拉刷新go. 1.在你的布局文件中加上你想用的

android使用PullToRefresh实现下拉刷新和上拉加载

PullToRefresh是一套实现非常好的下拉刷新库,它支持: 1.ListView 2.ExpandableListView 3.GridView 4.WebView 等多种常用的需要刷新的View类型,而且使用起来也十分方便. demo实例下载 下载完成,将它导入到eclipse中,作为一个library导入到你的工程中就好了. 一.废话少说,下拉刷新Go. 1.在你的布局文件中加上你想用的View就好了,比如这儿我想用一个支持下拉 刷新的ExpandableListView <com.h

Android仿XListView支持下拉刷新和上划加载更多的自定义RecyclerView_Android

首先给大家展示下效果图,感觉还不错,请继续往下阅读: 下拉刷新:        上划加载        在项目更新的过程中,遇到了一个将XListView换成recyclerView的需求,而且更换完之后大体效果不能变,但是对于下拉刷新这样的效果,谷歌给出的解决方案是把RecyclerView放在一个SwipeRefreshLayout中,但是这样其实是拉下一个小圆形控件实现的,和XListView的header效果不同.在网上找了很多的别人代码,都没有实现我想要的效果,于是自己动手写了一个.

Android仿XListView支持下拉刷新和上划加载更多的自定义RecyclerView

首先给大家展示下效果图,感觉还不错,请继续往下阅读: 下拉刷新: 上划加载 在项目更新的过程中,遇到了一个将XListView换成recyclerView的需求,而且更换完之后大体效果不能变,但是对于下拉刷新这样的效果,谷歌给出的解决方案是把RecyclerView放在一个SwipeRefreshLayout中,但是这样其实是拉下一个小圆形控件实现的,和XListView的header效果不同.在网上找了很多的别人代码,都没有实现我想要的效果,于是自己动手写了一个. 具体实现的效果有以下几条 下

不借助第三方插件利用ScrollView自身delegate实现下拉刷新和上拉加载

下拉刷新功能基本上在所有的app中都会被用到,而且这个功能已经被apple集成进去了,不过必须得是在tableViewController中才有,是一个叫做UIRefreshControl的控件,想看效果可以看手机QQ上面联系人列表下拉后的刷新.这里不多介绍. 本篇blog主要介绍如何在scrollview中实现下拉刷新的效果.因为有些时候我们可能更多地希望直接在scrollview中展现,而不是一定要局限于tableviewcontroller. 当然网上有很多下拉刷新和上拉加载的第三方控件,

Android RecyclerView实现下拉刷新和上拉加载_Android

RecyclerView已经出来很久了,许许多多的项目都开始从ListView转战RecyclerView,那么,上拉加载和下拉刷新是一件很有必要的事情. 在ListView上,我们可以通过自己添加addHeadView和addFootView去添加头布局和底部局实现自定义的上拉和下拉,或者使用一些第三方库来简单的集成,例如Android-pulltorefresh或者android-Ultra-Pull-to-Refresh,后者的自定义更强,但需要自己实现上拉加载. 而在下面我们将用两种方式

下拉刷新和上拉加载的原理

 很多App中,新闻或者展示类都存在下拉刷新和上拉加载的效果,网上提供了实现这种效果的第三方类(详情请见MJRefresh和EGOTableViewPullRefresh),用起来很方便,但是闲暇之余,我们可以思考下,这种效果实现的原理是什么,我以前说过,只要是动画都是骗人的,只要不是硬件问题大部分效果都能在系统UI的基础上做出来.             @下面是关键代码分析: [objc] view plaincopy // 下拉刷新的原理   - (void)scrollViewWillB