首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js 列表加载动画

在JavaScript中实现列表加载动画,通常涉及以下几个基础概念:

基础概念

  1. DOM操作:通过JavaScript操作HTML文档对象模型(DOM),动态地添加、删除或修改元素。
  2. CSS动画:使用CSS来创建动画效果,可以通过添加或移除CSS类来触发动画。
  3. 异步编程:使用JavaScript的异步特性(如Promiseasync/await)来处理数据加载,确保动画在数据加载期间显示。

优势

  • 用户体验:加载动画可以提升用户体验,让用户知道数据正在加载,而不是页面卡住。
  • 界面美观:动画效果可以使界面更加生动和专业。

类型

  1. 骨架屏:在数据加载前显示一个内容占位符,通常是灰色的矩形块,模拟最终内容的布局。
  2. 旋转加载器:常见的旋转图标,表示正在加载。
  3. 进度条:显示加载进度,适用于可以预估加载时间的场景。

应用场景

  • 分页加载:当用户滚动到页面底部时,加载更多数据。
  • 初始加载:页面首次加载时显示加载动画。
  • 数据请求:在进行API请求时显示加载动画。

实现示例

以下是一个简单的示例,展示如何在JavaScript中实现列表加载动画:

HTML

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>List Loading Animation</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div id="list-container">
        <div id="loading" class="loading">Loading...</div>
    </div>
    <button id="load-more">Load More</button>
    <script src="script.js"></script>
</body>
</html>

CSS (styles.css)

代码语言:txt
复制
.loading {
    text-align: center;
    font-size: 20px;
    color: #888;
}

.list-item {
    padding: 10px;
    border-bottom: 1px solid #ccc;
}

JavaScript (script.js)

代码语言:txt
复制
document.getElementById('load-more').addEventListener('click', async () => {
    const loading = document.getElementById('loading');
    loading.style.display = 'block'; // Show loading animation

    // Simulate an API call with setTimeout
    await new Promise(resolve => setTimeout(resolve, 2000));

    // Clear loading animation
    loading.style.display = 'none';

    // Add new items to the list
    const listContainer = document.getElementById('list-container');
    for (let i = 0; i < 5; i++) {
        const item = document.createElement('div');
        item.className = 'list-item';
        item.textContent = `Item ${listContainer.children.length + 1}`;
        listContainer.appendChild(item);
    }
});

解释

  1. HTML:包含一个用于显示加载动画的div和一个按钮来触发加载更多数据。
  2. CSS:定义了加载动画的样式和列表项的样式。
  3. JavaScript:当用户点击“Load More”按钮时,显示加载动画,模拟API调用(使用setTimeout),然后隐藏加载动画并添加新的列表项。

通过这种方式,可以在数据加载期间显示一个简单的加载动画,提升用户体验。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

5分48秒

5分钟实现漂亮的加载动画,CSS实现漂亮的加载动画

25.1K
14分23秒

93.尚硅谷_JS基础_文档的加载

8分41秒

66_尚硅谷_硅谷直聘_给列表界面添加动画效果.avi

24分29秒

11.视频列表集成xListView支持下拉刷新&加载更多.avi

4分30秒

day04_78_尚硅谷_硅谷p2p金融_提供加载中显示的drawable动画

8分1秒

Node.js入门到实战 21 用户列表 学习猿地

17分14秒

Golang教程 智能合约 54 加载js文件与启动私链挖矿 学习猿地

10分45秒

04-jQuery/10-尚硅谷-jQuery-原生js和jQuery页面加载完成之后的区别

9分45秒

Vue3.x项目全程实录 44_处理订单列表下拉加载更多 学习猿地

2分16秒

08.Gif动画_控制动画播放(下).avi

17分29秒

APICloud AVM多端开发 | 生鲜电商App开发商品列表,购物车,城市列表开发(二)

1分51秒

漂亮的满屏“心”动画效果,爱她就送给她吧!

领券