h5封装下拉刷新


Posted in HTML / CSS onAugust 25, 2020

前端在工作当中难免会于原生的安卓和ios合作,去做一些H5嵌套的页面。但是实际开发中常常会遇到各种兼容问题,具体问题我就不一一列举了,这次我主要分享的是关于在原生中下拉刷新中双系统出现的兼容问题,最典型的就是在ios中会出现下拉弹簧这会大大增加前端在开发中遇到的奇特问题,所以本文结合实际,对此做些功能上的实现,也希望大家可以看过我实现原理后理解并运用到实际的开发过程中,真正做到举一反三,货不多说直接上代码。

首页css+html部分

*{
            margin: 0;
            padding: 0;
            list-style: none;
        }
    body{
            display: flex;
            justify-content: center;
            align-items: center;
        }
    .one{
        width : 4rem;
        height: 7rem;
        border: 1px solid red;
        font-size: 0.35rem;
        box-sizing: border-box;
        overflow-y: auto;
       }
    .kl{
        position: relative;
       }
    .lis{
        width: 100%;
        height: 1rem;
        line-height: 1rem;
        text-align: center;
        background: red;
      }
    .lis:nth-child(2n+1){
    background: pink;
      }
    .scroll{
        height:100%;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        }
    .di{
    position: relative;
    color: #c8c9cc;
    font-size: 0;
    vertical-align: middle;
    }
    .k{
    width: 0.5rem;
    height: 0.5rem;
    display: inline-block;
    max-width: 100%;
    max-height: 100%;
    animation: theanimation 1s linear infinite;
    }
    .us{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
   color:rgb(25, 137, 250)
    }
    .us:before{
    display: block;
    width: 2px;
    height: 25%;
    margin: 0 auto;
    background-color: currentColor;
    border-radius: 40%;
    content: ' ';
    }
    .us:nth-child(1){
    -webkit-transform: rotate(30deg);
    transform: rotate(30deg);
    opacity: 1;
    }
    .us:nth-child(2){
    -webkit-transform: rotate(60deg);
    transform: rotate(60deg);
    opacity: 0.9375;
    }
    .us:nth-child(3){
        -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    opacity: 0.875;
    }
    .us:nth-child(4){
    -webkit-transform: rotate(120deg);
    transform: rotate(120deg);
    opacity: 0.8125;
    }
    .us:nth-child(5){
        -webkit-transform: rotate(150deg);
    transform: rotate(150deg);
    opacity: 0.75;
    }
    .us:nth-child(6){
        -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    opacity: 0.6875;
    }
    .us:nth-child(7){
        -webkit-transform: rotate(210deg);
    transform: rotate(210deg);
    opacity: 0.625;
    }
    .us:nth-child(8){
    -webkit-transform: rotate(240deg);
    transform: rotate(240deg);
    opacity: 0.5625;
    }
    .us:nth-child(9){
        -webkit-transform: rotate(270deg);
    transform: rotate(270deg);
    opacity: 0.5;
    }
    .us:nth-child(10){
        -webkit-transform: rotate(300deg);
    transform: rotate(300deg);
    opacity: 0.4375;
    }
    .us:nth-child(11){
    -webkit-transform: rotate(330deg);
    transform: rotate(330deg);
    opacity: 0.375;
    }
    .us:nth-child(12){
         -webkit-transform: rotate(360deg); 
    transform: rotate(360deg);
    opacity: 0.3125;
    }
    @keyframes theanimation{ 
  from {   transform: rotate(0deg);} 
    to { transform: rotate(360deg);} 
     } <!DOCTYPE html><html>	<head>		<meta charset="UTF-8">		<title>下拉刷新</title>		<link rel="stylesheet" type="text/css" href="botm_x.css"/>	</head>	<style type="text/css"> </style>	<body>		<div class="one" >			<div class="kl">			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>		    <li class="lis">这是一个内容</li>		 	<li class="lis">这是一个内容</li>		    <li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			<li class="lis">这是一个内容</li>			</div>	
	</div>
</body>	
<script type="text/javascript" src="适配.js">
</script>	
<script type="text/javascript" src="下拉刷新.js">
</script>
</html>

这里是模拟了一个简单的下拉刷新的模板。

h5封装下拉刷新

接下来是js部分也是最主要的部分

window.loading = function() {
    var sin = 0;
    var sel = null; //??r器
    var br = true; //判?嗍欠裾?求完所有的??
    var bl = true; //判?嗍欠?os an
    var all_H; //下拉高度
    var xl_xu, sl_xu; //下拉?和上拉?
    var str;
    let box = document.getElementsByClassName('one')[0] //?取到整??的body
    let box_childer = document.getElementsByClassName('kl')[0]
    let li = document.querySelectorAll('li') //所有的li
    box.addEventListener('touchstart', start) //摁下事件
    box.addEventListener('scroll', (e) => scrol(e)) //移?邮录
    box.addEventListener('touchend', end) //摁下??事件
    //    box.addEventListener('touchmove',move_lin)//拖拽事件
    function scrol(e) { //?L?邮录
        let move_scroll = br && bl ? e.target.scrollTop : NaN
        all_H = box.clientHeight + move_scroll
        if(all_H >= e.target.scrollHeight) { //?底了
            bl = false
            if(sin ^ 3) {
                ++sin
            } else {
                if(xl_xu) {
                    return
                }
                establish(2)
                return false
            }
            br = false
            //??建一?????盹@示所示?热
            establish();
        }
    }
    function end() { //鼠?穗x?事件
        bl = true
    }
    function start(e) { //摁下事件
        bl = true
    }
    function establish(a = 0) { //??建dom加?元素
        if(a == 2) { //?明是最後一?
            xl_xu = document.createElement('div');
            xl_xu.style.textAlign = 'center'
            xl_xu.innerHTML = '已?最後一?了'
            box_childer.appendChild(xl_xu)
            return
        }
        if(xl_xu) { //?明有 那就先?h除
            box_childer.removeChild(xl_xu)
        }
        xl_xu = document.createElement('div')
        xl_xu.style.textAlign = 'center'
        xl_xu.innerHTML = str
        box_childer.appendChild(xl_xu)
        sel = setTimeout(() => {
            box_childer.removeChild(xl_xu)
            xl_xu = null
            clearTimeout(sel);
            let a = Array.from({length: 5}, _ =>document.createElement('li'))
            for(let i = 0;i<a.length; i++)    {
                a[i].classList.add('lis') 
                box_childer.appendChild(a[i])
                }
            sel = null
            br = true
        }, 1500)
    }

    function move_lin(e) { //托?事件
        if(!br) {
            var eve = e || event
            var touch = eve.touches[0]
            var clientW = box.scrollWidth;
            var clientH = box.clientHeight
            var start_y = (750 / clientW) * (touch.pageY) / 75 //距离当前页面的高度
            var start_x = (750 / clientW) * (touch.pageX) / 75 //距离当前页面的宽度
            console.log(start_y, start_x)
        }

        //        console.log('托?了',box_childer,all_H)
    }
    (function() {
        str =`<div class="di"'>
                <div class="k">
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>             这里我写了一个下拉刷新的deom
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            <li class="us"></li>
            </div></div>`
    })()
}()

整个代码的思想不是简单意义上的根据滚动长度和实际高度做判断,以为开头说过ios这方面会有弹簧的一个特性,所以不能这么判断,我这边通过监听摁下松开事件来多上了一层锁,这样更加的安全和高效。

下面是我的效果演示,实际开发中可根据自己的用途来修改代码

h5封装下拉刷新

到此这篇关于h5封装下拉刷新的文章就介绍到这了,更多相关h5下拉刷新内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
深入CSS3 动画效果的总结详解
May 09 HTML / CSS
CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)
Jun 03 HTML / CSS
CSS3中currentColor关键字的妙用
Feb 27 HTML / CSS
CSS3制作漂亮的照片墙的实现代码
Jun 08 HTML / CSS
css3学习系列之移动属性详解
Jul 04 HTML / CSS
css3实现文字扫光渐变动画效果的示例
Nov 07 HTML / CSS
解决margin 外边距合并问题
Jul 03 HTML / CSS
移动端适配 使px自动转换rem
Aug 26 HTML / CSS
JavaScript+Canvas实现自定义画板的示例代码
May 13 HTML / CSS
基于Html5 canvas实现裁剪图片和马赛克功能及又拍云上传图片 功能
Jul 09 HTML / CSS
使用html2canvas实现将html内容写入到canvas中生成图片
Jan 03 HTML / CSS
html5中使用hotcss.js实现手机端自适配的方法
Apr 23 HTML / CSS
amazeui页面分析之登录页面的示例代码
Aug 25 #HTML / CSS
详解淘宝H5 sign加密算法
Aug 25 #HTML / CSS
AmazeUI 等分网格的实现示例
Aug 25 #HTML / CSS
AmazeUI 点击元素显示全屏的实现
Aug 25 #HTML / CSS
AmazeUI 按钮交互的实现示例
Aug 24 #HTML / CSS
amazeui页面校验功能的实现代码
Aug 24 #HTML / CSS
amazeui树节点自动展开折叠面板并选中第一个树节点的实现
Aug 24 #HTML / CSS
You might like
在服务端进行目录建立、删除,文件上传、删除的过程的php代码
2008/09/10 PHP
基于HTTP长连接的&quot;服务器推&quot;技术的php 简易聊天室
2009/10/31 PHP
Fatal error: Call to undefined function curl_init()解决方法
2010/04/09 PHP
php中的mongodb select常用操作代码示例
2014/09/06 PHP
CodeIgniter控制器之业务逻辑实例分析
2016/01/20 PHP
Yii框架实现邮箱激活的方法【数字签名】
2016/10/18 PHP
基于PHP实现解密或加密Cloudflar邮箱保护
2020/06/24 PHP
修复ie8&amp;chrome下window的resize事件多次执行
2011/10/20 Javascript
jQuery 图片切换插件(代码比较少)
2012/05/07 Javascript
解决html按钮切换绑定不同函数后点击时执行多次函数问题
2014/05/14 Javascript
javascript实现iframe框架延时加载的方法
2014/10/30 Javascript
IE浏览器下PNG相关功能
2015/07/05 Javascript
jQuery 获取多选框的值及多选框中文的函数
2016/05/16 Javascript
利用JS做网页特效_大图轮播(实例讲解)
2017/08/09 Javascript
Easy UI动态树点击文字实现展开关闭功能
2017/09/30 Javascript
vue 插值 v-once,v-text, v-html详解
2018/01/19 Javascript
Angular4.x通过路由守卫进行路由重定向实现根据条件跳转到相应的页面(推荐)
2018/05/10 Javascript
如何基于layui的laytpl实现数据绑定的示例代码
2020/04/10 Javascript
vue video和vue-video-player实现视频铺满教程
2020/10/30 Javascript
[05:31]DOTA2英雄梦之声_第04期_光之守卫
2014/06/23 DOTA
selenium python浏览器多窗口处理代码示例
2018/01/15 Python
Win8.1下安装Python3.6提示0x80240017错误的解决方法
2018/07/31 Python
pandas.cut具体使用总结
2019/06/24 Python
详解python中的time和datetime的常用方法
2019/07/08 Python
django的分页器Paginator 从django中导入类
2019/07/25 Python
Python并发请求下限制QPS(每秒查询率)的实现代码
2020/06/05 Python
新手学python应该下哪个版本
2020/06/11 Python
中国电子产品批发商/跨境电商/外贸网:Sunsky-online
2020/04/20 全球购物
医学专业毕业生个人的求职信
2013/12/04 职场文书
致标枪运动员广播稿
2014/02/06 职场文书
学校节能宣传周活动总结
2014/07/09 职场文书
镇政府副镇长群众路线专题民主生活会对照检查材料
2014/09/19 职场文书
先进个人材料怎么写
2014/12/30 职场文书
培训讲师开场白
2015/06/01 职场文书
《金钱的魔力》教学反思
2016/02/20 职场文书
2016年第十四个公民道德宣传日活动总
2016/04/01 职场文书