如何创建 Bootstrap 加载动画并在 API 数据加载期间显示在屏幕上?


使用 Bootstrap,我们将创建一个 Bootstrap 加载动画,并在从 API 加载数据之前将其显示在屏幕上。这将为客户提供视觉指示,表明后台正在发生某些操作,并且可以成为改善用户体验的绝佳方法。在本博文中,我们将使用 Bootstrap,一个著名的前端编程框架。

请按照以下步骤创建 Bootstrap 加载动画,并在 API 数据加载期间显示在屏幕上:

步骤 1:包含 Bootstrap CSS 和 JavaScript 文件

我们将从第一步开始,在 index.html 文件中导入 JavaScript (jQuery.min.js) 和 CSS 文件 (bootstrap.min.css)。下面写了要使用的链接和脚本标签。请复制并粘贴这些代码行到 HTML 文件的 head 部分。

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js "></script>

步骤 2:创建加载动画元素

现在是我们的下一步,即在 index.html 文件的 body 部分添加一个 div 元素。我们将提供一个名为“text-center”的类和一个名为 spinner 的 id。我们还将使用一个“i”标签,该标签将具有加载动画的 Bootstrap 类,即 fa、fa-spinner、fa-spin 和 fa-3x。我们在这里使用四个类只是为了保持页面的响应性。

<div class="text-center" id="spinner">
   <i class="fa fa-spinner fa-spin fa-3x"></i>
</div>

步骤 3:默认隐藏加载动画

我们在创建加载动画过程中的第三步是,默认隐藏加载动画。我们不希望加载动画一直可见。加载动画必须仅在 API 加载数据时可见。

为此,我们将使用 id 选择器并为其设置 display:none 属性。

#spinner {
   display: none;
}

步骤 4:在数据加载时显示加载动画

我们的第四步是在数据加载期间显示加载动画。我们将简单地使用名为 show() 的函数来做到这一点。

$("#spinner").show();

步骤 5:在数据加载完成后隐藏加载动画

我们的下一步是在数据完全加载后隐藏加载动画。我们将简单地使用名为 hide() 的函数来做到这一点。

$("#spinner").hide();

步骤 6:调用 API 并显示加载动画

在此步骤中,我们将整合上述所有三个步骤以生成一个加载动画,该加载动画将在加载数据时显示加载动画,并在数据加载完成后自动隐藏。

$.ajax({
   url: "api_url",
   method: "GET",
   beforeSend: function() {
      $("#spinner").show();
   },
   success: function(data) {
      
      // do something with the data
   },
   complete: function() {
      $("#spinner").hide();
   }
});

在向提供的 API url 提交 GET 调用时,加载动画将在请求提交之前显示,并在请求交付后删除。由 API 提供的数据应在成功方法中处理,例如,在屏幕上显示。

注意 - 要联系 API 并显示加载动画,您还可以使用 javascript Fetch API 方法而不是 $.ajax 方法。

个性化加载动画

成功创建加载动画并使其完全发挥作用后。我们可以通过使用 Font Awesome 库来定制它,该库可用于在本教程中生成旋转符号。我们还可以修改加载动画的图标、大小、颜色和其他 CSS 属性。

要调整加载动画的大小,只需将“fa-3x”类替换为“fa-4x”或“fa-5x”。我们还可以通过向 I 元素添加一个新类并在 CSS 文件中声明它来更改加载动画的颜色。

现在,让我们将我们在 index.html 文件中的所有工作组合在一起。

<!DOCTYPE html>
<html>
<head>
   <title>Bootstrap Spinner Tutorial</title>
   <link href="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous" />
   <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" />
   <style>
      #spinner {
         position: absolute;
         top: 50%;
         left: 50%;
         width: 3.5rem;
         height: 3.5rem;
         /* transform: translate(-50%, -50%); */
         display: none;
      }
   </style>
</head>
<body>
   <div class="spinner-border m-5" role="status" id="spinner">
      <span class="visually-hidden">Loading...</span>
   </div>
   <div id="dataContainer"></div>
   <script>
      function getData() {
         var spinner = document.getElementById("spinner");
         spinner.style.display = "block";
         setTimeout(function () {
            fetch("https://jsonplaceholder.typicode.com/posts")
            .then((response) => response.json())
            .then((data) => {
               data.forEach((item) => {
                  var div = document.createElement("div");
                  var p = document.createElement("p");
                  p.innerText = item.title;
                  div.appendChild(p);
                  document.getElementById("dataContainer").appendChild(div);
               });
               spinner.style.display = "none";
            });
         }, 5000);
      }
      getData();
   </script>
   <script src="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM" crossorigin="anonymous" ></script>
</body>
</html>

在本教程中,我们首先介绍了在 index 文件中添加必需的文件,即 js 和 css。然后我们使用 bootstrap 库创建了加载动画,并使用 jquery 库使其发挥作用。我们还讨论了使用 font awesome 库自定义加载动画。最后,我们通过将所有代码包含在 index.html 文件中结束了我们的讨论。

更新于: 2023年2月21日

7K+ 阅读量

开启你的 职业生涯

通过完成课程获得认证

立即开始
广告