JavaScript和REST API实现无限滚动分页

无限滚动分页的灵感来自 facebook 和 twitter 等网站。这只是分页,当用户滚动到页面底部时,会加载更多内容。这可以确保页面上始终有更多内容供用户阅读,从而改善网站上的用户体验。

正确执行无限滚动分页

当实现无限滚动分页时,有一些非常重要的要点需要记住。

重要链接不应位于页面底部。这是因为每次用户尝试向下滚动查找它们时,都会加载一组新的条目。所有重要的链接都应固定在侧边栏上或永久保留在顶部。

2.提前计划

计划好要在何处包含分页以及如何处理它非常重要。进行分页的常见方法是在页面底部列出页码。但是,当您使用无限滚动方法时,文章列表的末尾将不再出现页码,因为不再需要它们。只要您不在页脚部分包含大量信息,此分页就可以用于所有主题,因为它可能无法达到预期的效果。

在本教程中,我们将学习如何在 JavaScript 中实现无限滚动功能。

立即学习“Java免费学习笔记(深入)”;

该页面将显示有关猫的有趣事实列表,这些信息将来自 API。该 API 默认返回 10 个有趣的事实。当您滚动到页面底部时,应用程序将显示一个指示器来指示应用程序的加载状态。同时,应用程序将调用 API 来加载下一组有趣的事实。

我们将使用此 URL 来加载有趣的事实。 API 接受查询字符串 page,它告诉 API 要加载哪个页面。

https://catfact.ninja/facts?page=${page}&limit=${limit}

JavaScript和REST API实现无限滚动分页

现在,让我们开始使用该应用程序。

1. 创建项目结构

首先,创建一个具有以下结构的文件夹。

root-- index.html-- style.css-- app.js

2. 构建 HTML 文件

我们的 HTML 文件中将包含几个部分:

一个 container,其中将呈现整个可滚动的有趣事实列表包含每个有趣事实的 quotes 部分loader,加载有趣的事实时将可见。 loader 默认情况下是不可见的。

Fun Facts about Cats

3.构建脚本

接下来,我们需要创建一个脚本,它将连接 div 并加载有趣的事实。为此,我们将使用 querySelector()

const factsEl = document.querySelector('.facts');const loader = document.querySelector('.loader');

我们还需要一些控制变量来定义哪一组项目将显示在屏幕上。这段代码中的控制变量是:

currentPage当前页面初始化为1,当滚动到页面底部时,当前页面会加1,并发出API请求获取下一页的内容页。当页面滚动到顶部时,当前页面将减 1。total此变量存储 Fun Facts API 返回的报价总数。

4. 构建 getFacts 函数

getFacts函数的作用是调用API并返回有趣的事实。 getFacts 函数接受单个参数:page。它使用上面提到的 Fetch API 来获取无限滚动的数据。

Fetch 始终返回 promise,因此我们将使用 await-async 语法来接收和处理响应。要获取 json 数据,我们将使用 json() 函数。 getFacts 函数返回一个承诺,它将解析并返回 JSON。

const getfacts = async (page, limit) => {    const API_URL = `https://catfact.ninja/facts?page=${page}&limit=${limit}`;    const response = await fetch(API_URL);    // handle 404    if (!response.ok) {        throw new Error(`An error occurred: ${response.status}`);    }    return await response.json();}

5. 构建 showFacts 函数

既然我们已经收到了有趣的事实,我们可以在哪里显示这些事实呢?这就是为什么我们需要有一个 showFacts 函数。 showFacts 函数通过迭代 facts 数组来工作。然后,它使用 template Literal 语法创建 fact 对象 的 HTML 表示形式。

const showfacts = (facts) => {    facts.forEach(fact => {        const factEl = document.createElement('blockfact');        factEl.classList.add('fact');        factEl.innerHTML = `            ${fact.fact}        `;        factsEl.appendChild(factEl);    });};

生成的 blockFact 元素的示例是:

      Unlike dogs, cats do not have a sweet tooth. Scientists believe this is due to a mutation in a key taste receptor.

我们利用 appendChild 函数将 元素添加到容器中。

6.显示和隐藏加载指示器

当用户到达页面末尾时,必须显示加载指示器。为此,我们将引入两个函数:一个用于加载,另一个用于隐藏加载器。我们将使用 opacity: 1 显示加载程序,并使用 opacity: 0 隐藏加载程序。添加和删​​除 opacity 将分别显示/隐藏加载程序。

const hideLoader = () => {    loader.classList.remove('show');};const showLoader = () => {    loader.classList.add('show');};

7.查看更多有趣的事实

为了提高性能,我们将引入一个函数来检查 API 是否有更多事实。如果还有更多项目要获取,则 hasMoreFacts() 函数将返回 true。如果没有更多项目可供获取,API 调用将停止。

const hasMorefacts = (page, limit, total) => {    const startIndex = (page - 1) * limit + 1;    return total === 0 || startIndex < total;};

8. 编写 loadFacts 函数代码

loadFacts 函数负责执行这些重要操作:

显示或隐藏加载指示器调用 getFacts 函数获取更多事实展示事实

const loadfacts = async (page, limit) => {    // show the loader    showLoader();    try {        // if having more facts to fetch        if (hasMorefacts(page, limit, total)) {            // call the API to get facts            const response = await getfacts(page, limit);            // show facts            showfacts(response.data);            // update the total            total = response.total;        }    } catch (error) {        console.log(error.message);    } finally {        hideLoader();    }};

从某种意义上说,这种实现的一个缺点是它的运行速度。大多数时候您不会看到加载指示器,因为 API 可以很快返回。如果您想在每次滚动时查看加载指示器,可以使用 setTimeout 函数。调整 setTimeout 函数的 delay 将决定加载指示器显示的时间长度。

9. 处理滚动事件

当用户滚动到页面底部时,需要一个scroll事件处理程序来调用loadFacts函数。如果满足以下条件,该函数将被调用:

滚动条已到达页面底部还有更多事实需要加载

为了实现滚动事件,我们将使用三个窗口属性:

window.scrollHeight 给出整个文档的高度。window.scrollY 给出了用户滚动文档的距离。window.innerHeight 给出可见窗口的高度。

下图更好地概述了上述属性。另外,您将能够理解,如果 innerHeightscrollY 之和等于或大于 scrollHeight,则到达文档末尾,此时必须加载更多有趣的事实。

JavaScript和REST API实现无限滚动分页

window.addEventListener('scroll', () => {    const {        scrollTop,        scrollHeight,        clientHeight    } = document.documentElement;    if (scrollTop + clientHeight >= scrollHeight - 5 &&        hasMoreFacts(currentPage, limit, total)) {        currentPage++;        loadFacts(currentPage, limit);    }}, {    passive: true});

10.初始化页面

无限滚动的最后一步是初始化页面。调用 loadFacts 来加载第一组有趣的事实非常重要。

loadfacts(currentPage, limit);

现场演示

结论

现在,我们在 JavaScript 中实现了一个简单的无限滚动,每当用户滚动时,它将获取并呈现有关猫的有趣事实。这只是无限滚动最常用的方法之一。

以上就是JavaScript和REST API实现无限滚动分页的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1551882.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 22:08:09
下一篇 2025年12月19日 01:57:52

相关推荐

  • 如何使用JavaScript DOM创建表格标题?

    要创建表格标题,请使用 DOM createCaption() 方法。 示例 您可以尝试运行以下命令代码来学习如何创建表格标题 – 现场演示 function captionFunc(x) { document.getElementById(x).createCaption().inne…

    2025年12月21日
    000
  • 如何将当前数字返回为字符串值版本?

    toLocaleString() 方法返回当前数字的字符串值版本,其格式可能会根据浏览器的本地设置而有所不同。 示例 您可以尝试运行以下代码来返回字符串值版本 – JavaScript toLocaleString() Method var num = new Number(150.12…

    2025年12月21日
    000
  • 如何在HTML5中添加文章?

    在本文中,我们将学习如何在 HTML5 中添加文章。 HTML5 中的新分段元素之一是 标记。文章使用 标签以 HTML 形式表示。更具体地说, 元素中包含的内容与网站的其余内容不同(即使它们可能相关)。让我们考虑以下示例来了解如何在 HTML5 中添加文章 示例 1 在以下示例中,我们在文章元素中…

    2025年12月21日 好文分享
    000
  • “HTML标签”

    HTML 中的 applet 标签用于在 HTML 网页上设置 Java applet。 注意:HTML5 中不推荐使用 applet 标签。建议使用 或 元素。以下是属性 – 属性 值 描述 立即学习“前端免费学习笔记(深入)”; th> 对齐 URL 定义小程序周围的文本对齐 …

    2025年12月21日
    000
  • 如何提高JavaScript的性能?

    当今世界,几乎每个网站都使用 JavaScript。 Web 应用程序变得越来越复杂,用户交互性也越来越强,这导致了性能问题。它会导致糟糕的用户体验,这对于任何 Web 应用程序来说都是不可取的。不同的因素会导致性能差、加载时间长和响应时间长。 在本教程中,我们将讨论所有这些因素以及如何解决此问题并…

    2025年12月21日
    000
  • 点击HTML按钮或JavaScript时如何触发文件下载?

    现如今,许多应用程序允许用户进行文件的上传和下载。例如,抄袭检测工具允许用户上传一个包含一些文本的文档文件。然后,它会检查抄袭并生成报告,用户可以下载该报告。 每个人都知道使用input type file来创建一个上传文件按钮,但是很少有开发者知道如何使用JavaScript/ JQuery来创建…

    2025年12月21日
    000
  • 给WordPress帖子添加过期日期

    我运行了一些网站,这些网站在其主页的横幅中包含通知和重要信息。我倾向于为此使用自定义帖子类型,添加横幅并在主题中需要的位置显示它们。 (如果您想做类似的事情,本教程中对此进行了解释。) 但我的横幅总是有到期日。例如,它们可能包含有关即将举行的活动或职位空缺的信息。一旦活动结束或职位空缺被填补,我就必…

    2025年12月21日
    000
  • 在移动Safari中的HTML5地理定位“权限被拒绝”错误

    每当创建移动网站并要求用户在单击按钮时获取当前位置时,就会使用 HTML5 地理定位。这在移动 Chrome 中工作得很好。 但是,在 Mobile Safari 中,系统会提示用户共享位置,并且浏览器默认为地理定位,然后浏览器默认为权限被拒绝错误 为了解决此问题,移动服务中的地理定位服务是打开以获…

    2025年12月21日
    000
  • 如何用HTML将“布局”中的默认元标签替换为“视图”中的自定义元标签?

    元标签用于存储关于HTML文档的数据,例如作者和文档的描述。 最好的解决方案是在应用程序中定义默认标签,并在视图中覆盖默认参数。我们可以在PHP中这样做。 首先在配置文件中进行更改 − ’ demo@example.com’, ‘descrip’=&g…

    2025年12月21日
    000
  • 如何在HTML中指定要在中显示的页面的HTML内容?

    <img src="https://img.php.cn/upload/article/000/887/227/169432903346353.jpg" alt="如何在html中指定要在 HTML HTML 中的 标记指定内联框架。该内联框架用于在当前 HTML…

    2025年12月21日
    000
  • 将鼠标点击传递到覆盖的HTML元素

    检索点击事件中的鼠标坐标。  现在,通过隐藏叠加层来检索元素,并使用以下命令。之后,重新显示叠加层 – document.elementFromPoint(x, y) 您还可以使用以下 CSS – div { pointer-events:none;} 以上就是将鼠标点击传递…

    2025年12月21日
    000
  • 如何在HTML中合并表格单元格?

    我们使用 colspan 和 rowspan 属性来合并 HTML 中的单元格。 rowspan 属性用于指定单元格应合并的行数,而 colspan 属性用于指定单元格应合并的列数。 该属性应放置在 标记内。 语法 以下是在 HTML 中合并表格单元格的语法。 cell data 示例 以下是 HT…

    2025年12月21日
    000
  • 如何使用HTML和CSS删除填充颜色以更改图像颜色?

    在 Web 开发领域,了解最新的 CSS 和 HTML 技术对于向网站添加令人惊叹的视觉效果至关重要。其中一种效果是“颜色下降效果”,它允许您通过在图像上放置填充颜色来更改悬停时图像的颜色。 通过这种效果,您可以使您的网站对访问者更具互动性和吸引力。在本文中,我们将指导您完成使用 HTML 和 CS…

    2025年12月21日
    000
  • 如何在HTML中包含表格列的组?

    使用 标记包含表列组。HTML 标记用于指定表内一组列的属性。如果需要对 colgroup 中的列应用不同的属性,可以在 colgroup 标记中使用 HTML col 标记。 以下是属性 – 属性 值 描述 立即学习“前端免费学习笔记(深入)”; 对齐 右 左 居中 对齐 char 定…

    2025年12月21日
    000
  • 我们如何在HTML中显示文本区域的可见宽度?

    使用HTML中的cols属性来显示文本区域的可见宽度。您可以尝试运行以下代码来实现cols属性− 示例 This is a demo paragraph. This is a demo paragraph. This is a demo paragraph. This is a demo parag…

    2025年12月21日
    000
  • 在HTML中如何指定元素在页面加载时自动获取焦点?

    使用 autofocus 属性指定元素应在 HTML 中加载页面时自动获得焦点 – 示例 h2> 您可以尝试运行以下代码来了解如何在 HTML 中实现自动对焦属性 – Click on the below button to generate an alert box.…

    2025年12月21日
    000
  • 当一个元素在HTML中被悬停时,如何影响其他元素?

    要在一个元素悬停时影响其他元素,一个元素应该位于另一个元素内,即父子元素或同级元素。将鼠标光标放在一个元素上时,另一个元素的属性应该发生变化,即悬停效果可见。 当一个元素悬停时更改另一个元素的颜色 示例 在此示例中,我们将在鼠标悬停时更改 div 内两个框的颜色 – .parent { …

    2025年12月21日 好文分享
    000
  • 在HTML中,将元素所属的表单的名称设置为什么?

    使用 HTML 中的 form 属性来设置元素在 HTML 中所属的一个或多个表单的名称。 示例 您可以尝试运行以下代码来实现form属性 – SubjectID: Subject Name: Total Students: Click 以上就是在HTML中,将元素所属的表单的名称设置为…

    2025年12月21日
    000
  • 如何在HTML中指定用户可以输入多个值?

    在 HTML 中使用 multiple 属性来指定用户可以输入多个值。 示例 您可以尝试运行以下代码来实现多个属性 – Upload multiple files After uploading multiple files, click Submit. 以上就是如何在HTML中指定用户…

    2025年12月21日
    000
  • 如何创建一个包含多个固定尺寸图片的div

    概述 要使图像具有固定大小,可以通过设置 在下面的图像中,所有图像都是固定尺寸的,宽度尺寸为“18rem”,高度尺寸为“10rem”。图像的大小在代码的 head 标签的内部样式表中设置一次。 结论 使用外部样式表的优点是我们可以定位标签并设置其宽度和高度。因此,将来无论在父 div 中添加多少图像…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信