广告
返回顶部
首页 > 资讯 > 精选 >原生js怎么实现下拉刷新和上拉加载更多
  • 274
分享到

原生js怎么实现下拉刷新和上拉加载更多

2023-06-26 06:06:58 274人浏览 泡泡鱼
摘要

本篇文章为大家展示了原生js怎么实现下拉刷新和上拉加载更多,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。javascript是什么JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器

本篇文章为大家展示了原生js怎么实现下拉刷新和上拉加载更多,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

javascript是什么

JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分,主要用于WEB开发,可以给网站添加各种各样的动态效果,让网页更加美观。

1.下拉刷新

由于原生js太久不用了,这里列一下此处涉及到的前置知识点:

移动端触屏事件: touchstart(手指按下的一瞬间),touchmove(手指在屏幕上移动时),touchend(手指松开时)

手指在页面上的坐标: pageX,pageY

写之前首先要懂原理,下拉刷新的本质就是用户在页面顶部进行上拉动作时拉到一定的距离触发数据刷新.

大概需要做的几个点:

在手指按下时(touchstart)记录手指的按下位置

在手指下滑时(touchmove)计算手指的坐标离手指按下时初始位置的差值得出下滑的距离,让容器顺应手指下滑的方向移动(translateY)对应差值的距离,对应的给一个允许用户下滑的最大距离,避免页面下拉过长.

在手指松开时(touchend)判断下滑的差值是否达到预期的值来进行对应的刷新数据和回弹loading.

less Word,show me the code...

<!DOCTYPE html><html lang="en"> <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, maximum-scale=1.0, minimum-scale=1.0, user-Scalable=no">    <title>Document</title>    <style type="text/CSS">        * {            margin: 0;            padding: 0;            list-style: none;        }         .container {                        position: relative;            top: -100px;        }         .container .loading {            text-align: center;            height: 100px;            line-height: 100px;        }         .container .list {            border: 1px solid #666;        }         .container .list li {            line-height: 80px;        }         .container .list li:nth-child(2n) {            background-color: #ccc;        }    </style></head> <body>    <section class="container">        <section class="loading">            <span>下拉刷新</span>        </section>        <section class="list">            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>        </section>    </section></body><script type="text/javascript">    // 滚动容器    const container = document.querySelector('.container');    // loading文字容器    const span = container.querySelector('span');    let startPosition = 0;// 下拉的开始位置    let distance = 0;// 下拉距离的差值    // 手指按下时    container.addEventListener('touchstart', function (e) {        // 在回弹后的下一次下拉按下时重置loading文本        span.textContent = '下拉刷新';        // 记录开始位置        startPosition = e.touches[0].pageY;    })    // 手指移动时    container.addEventListener('touchmove', function (e) {        // 计算下拉差值        const currentPosition = e.touches[0].pageY;        // 计算下拉后离开始位置的差值        distance = currentPosition - startPosition;        // 如果下拉差值达到,则提示可以松手了 这个达到的具体值这里是取的下拉出来的区域高度        if (distance > 100) {// 案例以100为临界值,超过了100的距离就提示释放刷新            span.textContent = '释放刷新';        }        // 限制下滑的最大值为120,超过就不再下滑        if (distance < 120) {            // 容器的这个下滑是瞬时的 取消过渡效果            this.style.transition = 'transfORM 0s';            this.style.transform = `translateY(${distance}px)`        }    })    // 手指松开时    container.addEventListener('touchend', function (e) {        // 回弹的动作可以给个1s的过渡效果        this.style.transition = 'transform 1s';        // 如果下拉差值并没有达到 则直接回弹        if (distance > 0 && distance < 100) {            this.style.transform = `translateY(0px)`            return;        }        if (distance > 100) {            // 下拉差值达到了就显示刷新中,并暂时定格在这个位置            this.style.transform = `translateY(100px)`;            span.textContent = '刷新中';            // 等数据回来后显示刷新成功1s然后再回弹 到这里本次整个下拉执行完毕            setTimeout(() => {// setTimeout模拟异步请求 真实开发这里是一个promise请求                span.textContent = '刷新成功';                // 这个setTimeout让刷新成功显示一秒后再回弹                setTimeout(() => {                    this.style.transform = `translateY(0px)`                }, 1000)            }, 2000);        }        // 一次下拉结束后重置差值        distance = 0;    })</script> </html>

效果如图所示:

原生js怎么实现下拉刷新和上拉加载更多

2.上拉加载

前置js知识点: 三个dom属性
*clientHeight:不包含边框的元素可视区高度

*scrollTop:元素滚动时卷上去的距离

*scrollHeight: 元素实际高度,包含卷上去的高度

知道了上述三个属性后,于是就有了一个公式:

clientHeight + scrollTop <= scrollHeight - 触底的指定距离

然后就是上拉加载的原理:

通过监听元素的滚动事件(scroll)判断元素是否滚动到了距离底部指定距离时触发加载数据

知道了原理和三者之间的关系后,我们就知道只需要判断这个公式即可知道滚动条有没有进入触底距离,话不多说show code~

<!DOCTYPE html><html lang="en"> <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, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">    <title>Document</title>    <script src="https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.min.js"></script>    <style type="text/css">        * {            margin: 0;            padding: 0;            list-style: none;        }         .container {            height: 100vh;            overflow-y: scroll;        }         .container .list {            border: 1px solid #666;        }         .container .list li {            line-height: 80px;        }         .container .list li:nth-child(2n) {            background-color: #ccc;        }    </style></head> <body>    <section class="container">        <section class="list">            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>            <li>我是内容</li>        </section>    </section></body><script type="text/javascript" defer="defer">    // 滚动容器    const container = document.querySelector('.container');    // 监听滚动事件    container.addEventListener('scroll', _.debounce(function (e) {        // 当元素的可视高度+滚入的距离>=元素真实高度-触底距离时,触发加载更多        if ((this.clientHeight + this.scrollTop) >= this.scrollHeight - 50) {            setTimeout(() => {                // 这里是一个异步加载数据的操作                console.log('加载更多')            }, 1000);        }    }, 700))</script> </html>

效果如图:

原生js怎么实现下拉刷新和上拉加载更多

上述内容就是原生js怎么实现下拉刷新和上拉加载更多,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 原生js怎么实现下拉刷新和上拉加载更多

本文链接: https://www.lsjlt.com/news/307204.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作