JavaScript实现上拉加载下拉刷新

JavaScript实现上拉加载下拉刷新

1.前言

下拉刷新和上拉加载这两种交互方式通常出现在移动端中,本质上等同于PC网页中的分页,只是交互形式不同。

开源社区也有很多优秀的解决方案,如iscrollbetter-scrollpulltorefresh.js库等等。

下面通过原生的方式实现上拉加载,下拉刷新,有助于对第三方库有更好的理解与使用。

2.上拉加载

如下看一张图:
在这里插入图片描述
我们可以知道:实现上拉加载的关键点是判断页面触底,或者判断是否快要触底。即scrollTop+clientHeight>= scrollHeight

这几个属性我在之前三大家族文章https://blog.csdn.net/fageaaa/article/details/145728760里面详细讲解过。下面来回忆一下:

  • scrollTop:滚动视窗的高度距离window顶部的距离,它会随着往上滚动而不断增加,初始值是0,它是一个变化的值
  • clientHeight:它是一个定值,表示屏幕可视区域的高度;
  • scrollHeight:页面不能滚动时也是存在的,此时scrollHeight等于clientHeight。scrollHeight表示body所有元素的总长度(包括body元素自身的padding)。

简单实现:

let clientHeight  = document.documentElement.clientHeight; //浏览器高度
let scrollHeight = document.body.scrollHeight;
let scrollTop = document.documentElement.scrollTop;
 
let distance = 50;  //距离视窗还用50的时候,开始触发;

if ((scrollTop + clientHeight) >= (scrollHeight - distance)) {
   
    console.log("开始加载数据");
}

下面再看一个详细的例子:
在这里插入图片描述

如上图,我们需要实现的是:页面总共要加载1000条数据,但不可能一开始直接一次性加载在页面上。如图,一次性只加载20条数据,所以一开始页面加载了20条数据,会有一个滚动条,但这个滚动条距离底部很近(大概两个多条目高度的距离,因为最底部条目是item18,总共有20个条目)。当我们向下移动滚动条时候,当发现快要触底时候,我们会自动再加载20条数据,向上滚动时候不加载,因为向上滚动时的条目都是已经加载在页面上的条目了,不用再加载。依次类似诸如此类。

如下我们实现一下代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>Title</title>
    <style>
      body,
      html {
   
        padding: 0px;
        margin: 0px;
        width: 100%;
        height: 100%;
        overflow: hidden;
      }

      ul {
   
        margin: 0;
        width: 90%;
        height: 100%;
        overflow-y: auto;
        list-style: none;
      }

      ul > li {
   
        width: 100%;
        height: 40px;
      }

      ul > li:nth-of-type(2n + 1) {
   
        background-color: aqua;
      }

      ul > li:nth-of-type(2n) {
   
        background-color: antiquewhite;
      }
    </style>
  </head>
  <body>
    <ul></ul>
    <script>
      //初始化一个1000大小的数组-->
      // 真实开发中࿰
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值