zoukankan      html  css  js  c++  java
  • h5向下刷新

    使用iscroll-probe实现向下刷新还是有点不太友好,因为他只要是实现容器滚动上模仿移动端滑动,

    所以为实时监听滚动事件等,而在滚动后放开手指等没有监听所以向下刷新的效果在某些情况是无法实现的。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
        <title>Document</title>
        <script src="./jquery.js" type="text/javascript" charset="utf-8"></script>
        <script type="text/javascript" src="./iscroll-probe.js"></script>
        <style>
        * {  
            -webkit-box-sizing: border-box;  
            -moz-box-sizing: border-box;  
            box-sizing: border-box;  
           }  
                  
        html {  
            -ms-touch-action: none;  
        }  
          
        body,ul,li {  
            padding: 0;  
            margin: 0;  
            border: 0;  
        }  
          
        html,body {  
            font-size: 12px;  
            font-family: ubuntu, helvetica, arial;  
             100%;
            height: 100%;
            overflow: hidden;  
        }  
        #wrapper {
            position: absolute;
            z-index: 1;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            background: #ccc;
            overflow: hidden;
        }
        #scroller {
            position: absolute;
            z-index: 1;
            -webkit-tap-highlight-color: rgba(0,0,0,0);
             100%;
            -webkit-transform: translateZ(0);
            -moz-transform: translateZ(0);
            -ms-transform: translateZ(0);
            -o-transform: translateZ(0);
            transform: translateZ(0);
            -webkit-touch-callout: none;
            -webkit-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none;
            -webkit-text-size-adjust: none;
            -moz-text-size-adjust: none;
            -ms-text-size-adjust: none;
            -o-text-size-adjust: none;
            text-size-adjust: none;
        }
        #pullDown,  
        .pulldown-tips {  
            height: 40px;  
            line-height: 40px;  
            text-align: center;  
        }  
        .pulldown-tips {  
            position: absolute;  
            top: -40px;  
            left: 0;  
             100%;  
        }
        .content{
             100%;
            height: 1000px;
            background: rgba(255,0,0,0.2);
        }
        .pullDown{
            display: none;
        }
        </style>
    </head>
    <body>
        <div id="wrapper">
            <div id="scroller">
                <div id="pullDown" class="pullDown">  
                    <div class="pullDownLabel"></div>  
                </div>  
                <div class="pulldown-tips">下拉刷新</div>
                <div class="content">
                    
                </div>
            </div> 
        </div>
    
        <script>
    window.onload=function(){
        load();
        
    
        //加载状态 0默认,1显示加载状态,2执行加载数据,只有当为0时才能再次加载,这是防止过快拉动刷新 
        var loadingStep = 0;  
        var $pullDown = $("#pullDown"),
            $pullDownLabel = $pullDown.find(".pullDownLabel"),
            $pulldownTips = $(".pulldown-tips");
    
        function load(){
            myScroll = new IScroll("#wrapper", {  
                    scrollbars: true,  
                    mouseWheel: false,  
                    interactiveScrollbars: true,  
                    shrinkScrollbars: 'scale',  
                    fadeScrollbars: true,  
                    scrollY: true,  
                    probeType: 2,  
                    bindToWrapper: true  
                });
    
            myScroll.on('scroll', updateRefresh);
            myScroll.on('scrollEnd', updateEnd);
            document.addEventListener('touchmove', function(e) { e.preventDefault(); }, false);
        }
    
    
        function updateRefresh () {
            if(loadingStep == 0&&!$pullDown.hasClass("refresh")){
                if(this.y > 40){
                    loadingStep = 1;
                    $pullDown.addClass("refresh").show();
                    $pullDownLabel.text("松手刷新数据");
                    $pulldownTips.hide();
                    // 因为加入div所以要重新计算滚动的高度,但放开手指后刷新高度会出现抖动
                    myScroll.refresh();
                }
            }
        }
        function updateEnd () {
            if(loadingStep == 1&& $pullDown.hasClass("refresh")){
                loadingStep = 2;
                $pullDown.removeClass("refresh");
                $pullDownLabel.text("正在刷新");
                refreshData();
            }
        }
    
        function refreshData(){
            console.log(1);
            setTimeout(function(){
                loadingStep = 0;
                $pullDown.hide();
                $pulldownTips.show();
                myScroll.refresh();
    
            },5000);
        }
    
    }    
        </script>
    </body>
    </html>

    所以可以找专门实现向下刷新,向上加载的插件

    mescroll

    它是一个不错的插件,里面很多例子,案例也是一些大型著名app的实现案例。

  • 相关阅读:
    Eclipse安装TestNG插件
    总结Selenium WebDriver中一些鼠标和键盘事件的使用
    【资料收集】AutomationGuru
    centos7.4 yum安装包出现网络不可达跟Recv failure: Connection reset by peer" 这个问题
    ubuntu配置ntp
    OpenStack-ansible ubuntu16.04安装&& centos7 安装 && openSUSE 安装OpenStack-ansible
    HSRP&&STP&&ACL
    vlan通讯&&动态路由
    cisco交换机基本配置
    cisco教程 怎么改console密码 主机名 各种模式的切换等
  • 原文地址:https://www.cnblogs.com/zhangzhicheng/p/8547065.html
Copyright © 2011-2022 走看看