您的位置:首页 > 新闻 > 会展 > 网络营销专业专升本_企业查询app排行榜_手游推广渠道_百度应用下载

网络营销专业专升本_企业查询app排行榜_手游推广渠道_百度应用下载

2025/1/1 21:26:58 来源:https://blog.csdn.net/qq_37117408/article/details/142145662  浏览:    关键词:网络营销专业专升本_企业查询app排行榜_手游推广渠道_百度应用下载
网络营销专业专升本_企业查询app排行榜_手游推广渠道_百度应用下载

基于HTML5的下拉刷新效果

    • 效果示例图
    • 示例代码

效果示例图

在这里插入图片描述

示例代码

<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width,initial-scale=1.0" /><title></title><style type="text/css">* {padding: 0;margin: 0;box-sizing: border-box;}.main {width: 100%;height: 100vh;background-color: #f5f5f5;position: relative;}.dot-wrap {width: 100%;height: 30px;position: absolute;background-color: #fff;top: -30px;}.dot {position: absolute;width: 10px;height: 10px;border-radius: 10px;background-color: rgb(0, 0, 0, 0.3);top: 0;left: 50%;margin-left: -5px;}.dot:last-child {display: none;}.dot.loading {display: unset;animation: dot-move 1.5s infinite;}@keyframes dot-move {0% {transform: translateX(-20px);}33.33% {transform: translateX(-20px);}33.34% {transform: translateX(0px);}66.66% {transform: translateX(0px);}66.67% {transform: translateX(20px);}100% {transform: translateX(20px);}}.block-item {width: 100%;height: 200px;background-color: red;margin-bottom: 12px;}</style></head><body><div class="main"><div class="dot-wrap"><div class="dot"></div><div class="dot"></div><div class="dot"></div><div class="dot"></div></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div><div class="block-item"></div></div></body><script type="text/javascript">let timerHandle = null;const mainDom = document.querySelector(".main");const dots = document.querySelectorAll(".dot");const rootDocument = document.documentElement;//当滚动条在最顶部时可以下拉刷新if (rootDocument.scrollTop === 0) {addTouchEvent();}//滚动监听window.onscroll = function() {//当滚动条到达顶部时,可以触发下拉拖动事件if (rootDocument.scrollTop <= 0) {rootDocument.scrollTop = 0;addTouchEvent();} else {removeTouchEvent();}}let distance, ox, oy, x, y = 0;function startEvent(e) {console.log("[start]", e)//获取手指起始值ox = e.touches[0].clientX;oy = e.touches[0].clientY;}function moveEvent(e) {if (!e.cancelable) {return; // 如果事件不可取消,直接返回,避免报错}//获取手指移动值x = e.touches[0].clientX;y = e.touches[0].clientY;//判断下拉意图if (y - oy > 0) {const deg = Math.atan(Math.abs(x - ox) / Math.abs(y - oy)) / Math.PI * 180;if (deg > 40) {ox = x;oy = y;return false;}} else {removeTouchEvent();if (rootDocument.scrollTop === 0) {addTouchEvent();return false;}}//手指移动的距离distance = y - oy;//添加阻尼效果let percent = (100 - distance * 0.5) / 100;percent = percent < 0.5 ? 0.5 : percent;distance = distance * percent//设置页面偏移距离mainDom.style.transform = `translateY(${distance}px)`console.log("[move]", distance)if (distance > 20 && distance <= 50) {dots[0].style.transform = `translateX(-${(distance-20)*2/3}px)`;dots[2].style.transform = `translateX(${(distance-20)*2/3}px)`;} else if (distance > 50) {dots[0].style.transform = `translateX(-20px)`;dots[2].style.transform = `translateX(20px)`;}e.preventDefault();}function endEvent() {//当拖动的相对值大于50时if (distance >= 50) {//可以触发下拉刷新dots[3].classList.add('loading')mainDom.style.transition = `all 0.2s`;mainDom.style.transform = `translateY(50px)`if (timerHandle) {clearTimeout(timerHandle)}timerHandle = setTimeout(() => {if (timerHandle) {clearTimeout(timerHandle)}removeEffect()}, 2000);} else {removeEffect()}}function removeEffect() {//清除过渡效果mainDom.style.transition = `all 0.2s`;mainDom.style = '';dots[3].classList.remove('loading')}function addTouchEvent() {/*** 通过将`passive`设置为`false`,表示在触发`touchmove`事件时,事件处理函数可以调用`preventDefault()`来阻止默认行为。* 这意味着在移动过程中,可以阻止浏览器执行默认的滚动行为。*/mainDom.addEventListener('touchstart', startEvent, {passive: false});mainDom.addEventListener("touchmove", moveEvent, {passive: false})mainDom.addEventListener('touchend', endEvent, {passive: false})}function removeTouchEvent() {mainDom.removeEventListener('touchstart', startEvent);mainDom.removeEventListener("touchmove", moveEvent)mainDom.removeEventListener('touchend', endEvent)}</script>
</html>

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com