使用CSS实现一个加载的进度条

文章目录

  • 使用CSS实现一个加载的进度条
    • 一、引言
    • 二、步骤一:HTML结构与CSS基础样式
      • 1、HTML结构
      • 2、CSS基础样式
    • 三、步骤二:添加动画效果
      • 1、使用CSS动画
      • 2、结合JavaScript控制动画
    • 四、使用示例
    • 五、总结

使用CSS实现一个加载的进度条

在这里插入图片描述

一、引言

在现代网页设计中,加载速度对用户体验至关重要。为了提升用户体验,加载进度条成为了一个常见的交互元素。它不仅能告知用户页面加载的进度,还能减少用户等待时的焦虑感。本文将详细介绍如何使用纯CSS实现一个简单的加载进度条,并结合动画效果使其更具吸引力。

二、步骤一:HTML结构与CSS基础样式

1、HTML结构

首先,我们需要在HTML中创建一个用于显示进度条的容器。通常,这个容器是一个div元素,内部包含一个用于表示进度条的span元素。

<div id="progress">
  <span></span>
</div>

2、CSS基础样式

接下来,我们为进度条添加基础样式。设置容器的宽度、高度、边框和圆角,并为进度条部分设置背景颜色。

#progress {
  width: 50%;
  height: 20px;
  border: 1px solid #ccc;
  border-radius: 10px;
  overflow: hidden;
  margin: 50px auto;
}

#progress span {
  display: block;
  height: 100%;
  width: 0;
  background-color: #2989d8;
  transition: width 0.5s ease;
}

三、步骤二:添加动画效果

1、使用CSS动画

为了使进度条具有动态加载的效果,我们可以使用CSS的@keyframes规则来定义一个动画。这个动画将使进度条的宽度从0%逐渐增加到100%。

@keyframes progress {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

#progress span {
  animation: progress 2s infinite;
}

2、结合JavaScript控制动画

虽然CSS动画可以实现进度条的动态效果,但实际应用中,我们通常需要根据页面加载的真实进度来更新进度条。这时,可以使用JavaScript来动态调整进度条的宽度。

let progressBar = document.querySelector('#progress span');
let progress = 0;

function updateProgress() {
  if (progress < 100) {
    progress += 10;
    progressBar.style.width = progress + '%';
    setTimeout(updateProgress, 500);
  }
}

updateProgress();

四、使用示例

以下是一个完整的示例,展示了如何结合HTML、CSS和JavaScript实现一个动态加载的进度条。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>CSS加载进度条</title>
  <style>
    #progress {
      width: 50%;
      height: 20px;
      border: 1px solid #ccc;
      border-radius: 10px;
      overflow: hidden;
      margin: 50px auto;
    }

    #progress span {
      display: block;
      height: 100%;
      width: 0;
      background-color: #2989d8;
      transition: width 0.5s ease;
    }

    @keyframes progress {
      0% {
        width: 0;
      }
      100% {
        width: 100%;
      }
    }
  </style>
</head>
<body>
  <div id="progress">
    <span></span>
  </div>

  <script>
    let progressBar = document.querySelector('#progress span');
    let progress = 0;

    function updateProgress() {
      if (progress < 100) {
        progress += 10;
        progressBar.style.width = progress + '%';
        setTimeout(updateProgress, 500);
      }
    }

    updateProgress();
  </script>
</body>
</html>

五、总结

通过本文的介绍,我们学习了如何使用CSS和JavaScript实现一个简单的加载进度条。CSS提供了丰富的动画功能,而JavaScript则可以帮助我们根据实际加载进度动态更新进度条。这种组合不仅提升了用户体验,还使页面加载过程更加直观。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • CSS实现进度条和订单进度条的示例
  • CSS3实现页面加载进度条

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/961601.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Oracle 创建用户和表空间

Oracle 创建用户和表空间 使用sys 账户登录 建立临时表空间 --建立临时表空间 CREATE TEMPORARY TABLESPACE TEMP_POS --创建名为TEMP_POS的临时表空间 TEMPFILE /oracle/oradata/POS/TEMP_POS.DBF -- 临时文件 SIZE 50M -- 其初始大小为50M AUTOEXTEND ON -- 支持…

图漾相机——C++语言属性设置

文章目录 前言1.SDK API功能介绍1.1 Device组件下的API测试1.1.1 相机工作模式设置&#xff08;TY_TRIGGER_PARAM_EX&#xff09;1.1.2 TY_INT_FRAME_PER_TRIGGER1.1.3 TY_INT_PACKET_DELAY1.1.4 TY_INT_PACKET_SIZE1.1.5 TY_BOOL_GVSP_RESEND1.1.6 TY_BOOL_TRIGGER_OUT_IO1.1.…

NoSQL与SQL比较

1.认识NoSQL NoSql可以翻译做Not Only Sql&#xff08;不仅仅是SQL&#xff09;&#xff0c;或者是No Sql&#xff08;非Sql的&#xff09;数据库。是相对于传统关系型数据库而言&#xff0c;有很大差异的一种特殊的数据库&#xff0c;因此也称之为非关系型数据库。 1.1.结构…

【Unity教程】零基础带你从小白到超神part3

粒子系统 在创建粒子系统之前&#xff0c;需要先添加一些粒子样式&#xff0c;这可以在资源商店中通过导入官方提供的StandardAssets资源包得到。完成资源的导入后&#xff0c;该资源包中的StandardAssets>ParticleSystems>Prefabs文件夹下包含多种成品粒子效果&#xf…

FastExcel使用详解

文章目录 FastExcel使用详解一、引言二、环境准备与依赖引入1、Maven 依赖引入2、实体类定义 三、核心操作&#xff1a;读写 Excel1、读取 Excel1.1 自定义监听器1.2 读取文件 2、写入 Excel2.1 简单写入2.2 模板写入 四、Spring Boot 集成示例1、文件上传&#xff08;导入&…

智能调度体系与自动驾驶技术优化运输配送效率的研究——兼论开源AI智能名片2+1链动模式S2B2C商城小程序的应用潜力

摘要&#xff1a;随着全球化和数字化进程的加速&#xff0c;消费者需求日益呈现出碎片化和个性化的趋势&#xff0c;这对物流运输行业提出了前所未有的挑战。传统的物流调度体系与调度方式已难以满足当前复杂多变的物流需求&#xff0c;因此&#xff0c;物流企业必须积极引入大…

数据结构与算法分析:专题内容——人工智能中的寻路4之A*搜索(代码详解)

一、算法描述 广度优先搜索能够找到一个最优解&#xff08;如果存在&#xff09;&#xff0c;但是可能需要访问大量的节点&#xff0c;因为我们可以看到&#xff0c;它并没有尝试对候选走法进行排序。相反&#xff0c;深度优先搜索却是尽可能多地向前探测路径&#xff0c;不过…

vue3相关知识点

title: vue_1 date: 2025-01-28 12:00:00 tags:- 前端 categories:- 前端vue3 Webpack ~ vite vue3是基于vite创建的 vite 更快一点 一些准备工作 准备后如图所示 插件 Main.ts // 引入createApp用于创建应用 import {createApp} from vue // 引入App根组件 import App f…

零基础Vue入门4——Vue3基础核心

本节重点&#xff1a; vue3最佳实践 ref reactive computed watch、watchEffect 讲解重点之后下面会带大家开发一个页面&#xff08;表单表格&#xff09;&#xff0c;之后会有一个TodoList的小练习&#xff0c;文末附有小练习的代码参考。跟着练习一定带你可以上手开发vu…

文件上传2

BUUCTF 你传你&#x1f40e;呢 先上传.htaccess 修改格式 即可上传成功 返回上传图片格式的木马 用蚁剑连接 5ecf1cca-59a1-408b-b616-090edf124db5.node5.buuoj.cn:81/upload/7d8511a847edeacb5385299396a96d91/rao.jpg 即可得到flag [GXYCTF2019]BabyUpload

网安加·百家讲坛 | 樊山:数据安全之威胁建模

作者简介&#xff1a;樊山&#xff0c;锦联世纪教育能源工业互联网数字安全CSM(新能源运维师)课程特聘培训讲师&#xff0c;哈尔滨工业大学&#xff08;深圳&#xff09;信飞合创数据合规联合实验室特聘专家&#xff0c;武汉赛博网络安全人才研究中心资深专家&#xff1b;近24年…

联想Y7000+RTX4060+i7+Ubuntu22.04运行DeepSeek开源多模态大模型Janus-Pro-1B+本地部署

直接上手搓了&#xff1a; conda create -n myenv python3.10 -ygit clone https://github.com/deepseek-ai/Janus.gitcd Januspip install -e .pip install webencodings beautifulsoup4 tinycss2pip install -e .[gradio]pip install pexpect>4.3python demo/app_januspr…

冬天适合养什么鱼?

各位鱼友们&#xff0c;冬天来了&#xff0c;是不是还在为养什么鱼而烦恼&#xff1f;别担心&#xff0c;今天就来给大家好好推荐一些适合冬天养的鱼&#xff0c;让你的水族箱在寒冷的冬天也能生机勃勃&#xff01; 一、金鱼&#xff1a;冬日里的“小暖男” 金鱼绝对是冬季养鱼…

2024年终总结

回顾 今年过年没回老家&#xff0c;趁着有时间&#xff0c;总结一下24年吧。 我把23年看做是打基础的一年&#xff0c;而24年主要是忙于项目的一年&#xff0c;基本上大部分时间都是忙着交付软件&#xff0c;写的一些文章也大部分都是项目中遇到的问题和解决方案&#xff0c;虽…

安宝特方案 | 智能培训:安宝特AR如何提升企业技能培训的效率与互动性

随着企业不断推进数字化转型&#xff0c;传统培训方式已无法满足现代企业对高效、灵活培训的需求。尤其在技术更新频繁、工艺流程复杂、员工流动性大的环境中&#xff0c;传统培训模式的局限性愈加明显。为了提升培训质量、降低培训成本&#xff0c;并帮助员工迅速掌握新技能&a…

1.27补题 回训练营

E 智乃的小球 题目描述 在一条无限长的水平直线上&#xff0c;有 n 个小球&#xff0c;每个小球的质量相同&#xff0c;体积可以忽略不计。这些小球初始时位于直线上的不同位置&#xff0c;并且每个小球有一个初始速度&#xff0c;速度为 -1 m/s 或 1 m/s。速度为 -1 m/s 表示…

Spring Boot 实现文件上传和下载

文章目录 Spring Boot 实现文件上传和下载一、引言二、文件上传1、配置Spring Boot项目2、创建文件上传控制器3、配置文件上传大小限制 三、文件下载1、创建文件下载控制器 四、使用示例1、文件上传2、文件下载 五、总结 Spring Boot 实现文件上传和下载 一、引言 在现代Web应…

CTFSHOW-WEB入门-命令执行39-53

题目&#xff1a;web 39 题目&#xff1a;解题思路&#xff1a;分析代码可以知道题目要求get一个c的参数&#xff0c;并且过滤了flag&#xff0c;大小写均过滤&#xff0c;于是可以想到使用&#xff1f;或者*通配符绕过。这里有include函数&#xff0c;由于include是个漏洞函数…

OpenCSG月度更新2025.1

1月的OpenCSG取得了一些亮眼的成绩 在2025年1月&#xff0c;OpenCSG在产品和社区方面继续取得了显著进展。产品方面&#xff0c;推出了AutoHub浏览器自动化助手&#xff0c;帮助用户提升浏览体验&#xff1b;CSGHub企业版功能全面升级&#xff0c;现已开放试用申请&#xff0c…

HTML(快速入门)

欢迎大家来到我的博客~欢迎大家对我的博客提出指导&#xff0c;有错误的地方会改进的哦~点击这里了解更多内容 目录 一、前言二、HTML基础2.1 什么是HTML?2.2 认识HTML标签2.2.1 HTML标签当中的基本结构2.2.2 标签层次结构 2.3 HTML常见标签2.3.1 标题标签2.3.2 段落标签2.3.3…