html下滑刷新原理,移动端下拉刷新原理和实例

移动端的下拉刷新是一个很常见的功能,也有许多开源库实现了这个功能,不过为了学习,还是先自己写一个例子学习一下。其中用到了一些touch事件和一些DOM属性CSS3属性。直接上代码,代码里面有注释。

Document

html,

body,

header,

div,

main,

p,

span,

ul,

li {

margin: 0;

padding: 0;

}

#refreshContainer li {

background-color: #eee;

margin-bottom: 1px;

padding: 20px 10px;

}

.refreshText {

position: absolute;

width: 100%;

line-height: 50px;

text-align: center;

left: 0;

top: 0;

transform: translateY(-50px);

}

  • 111
  • 222
  • 333
  • 444
  • 555
  • 111
  • 222
  • 333
  • 444
  • 555
  • 111
  • 222
  • 333
  • 444
  • 555

window.onload = function(){

//1.获取到列表的dom,刷新显示部分的dom,列表父容器的dom

let container = document.querySelector('#refreshContainer');

let refreshText = document.querySelector('.refreshText');

let parent = document.querySelector('.parent');

//2.定义一些需要常用的变量

let startY = 0;//手指触摸最开始的Y坐标

let endY = 0;//手指结束触摸时的Y坐标

//3.给列表dom监听touchstart事件,得到起始位置的Y坐标

parent.addEventListener('touchstart',function(e){

startY = e.touches[0].pageY;

});

//4.给列表dom监听touchmove事件,当移动到一定程度需要显示上面的文字

parent.addEventListener('touchmove',function (e) {

if(isTop() && (e.touches[0].pageY-startY) > 0){

console.log('下拉了');

refreshText.style.height = "50px";

parent.style.transform = "translateY(50px)";

parent.style.transition = "all ease 0.5s";

refreshText.innerHTML = "释放立即刷新...";

}

});

//5.给列表dom监听touchend事件,此时说明用户已经松开了手指,应该进行异步操作了

parent.addEventListener('touchend',function (e) {

if(isTop()){

refreshText.innerHTML = "正在刷新...";

setTimeout(function(){

parent.style.transform = "translateY(0)";

console.log('成功刷新');

},2000)

}

return;

})

function isTop(){

var t = document.documentElement.scrollTop||document.body.scrollTop;

return t === 0 ? true : false;

}

}

其中用到了CSS3中的transform和animate。因为既然都是移动端了,这些东西基本上都支持了。

具体看代码吧,注释也有。本文只是讲解原理,后续将会对其进行封装成一个对象。方便直接调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值