当前位置: 首页 > news >正文

仅 CSS 阅读进度条

为了构建一个阅读进度条,即显示用户向下滚动时阅读文章的进度,很难不考虑 JavaScript。但是,事实证明,您也可以使用纯 CSS 构建阅读进度条。

从本质上讲,一个名为 animation-timeline 的新实验性 CSS 属性可以让你指定用于控制 CSS 动画进度的时间轴。我们将用它来创建阅读进度条。

首先,我们需要定义一个用作进度条的 div 元素。我们将使用一个固定在视口顶部的容器来包装这个 div 。这将确保用户向下滚动页面时进度条始终可见。

<div class="progress-bar-container"><div class="progress-bar"></div>
</div>
<div class="content"><!-- content goes here -->
</div>

接下来,我们将定义进度条的样式。我们将设置 progress-bar-container 固定在视口顶部并调整其背景颜色,该颜色始终对用户可见。我们还将 progress-bar 设置为 100% 宽度。

.progress-bar-container {position: fixed;top: 0px;width: 100%;background: #6c2fa2;z-index: 999;
}

现在,为了使进度条动画化,我们将为 progress-bar 使用不同的背景颜色,并将其高度设置为 7px 。我们还将 animation-name 设置为 width ,这实际上将进度条的宽度从 0 动画到 100%

最后,我们将 animation-timeline 设置为 scroll(y) ,将动画时间轴绑定到视口的垂直滚动位置。这将确保当用户向下滚动页面时进度条具有动画效果。

.progress-bar {height: 7px;background: #e131ff;animation-name: width;/* animation timeline is tied to vertical scroll position */animation-timeline: scroll(y);
}@keyframes width {from { width: 0 }to   { width: 100% }
}

就是这样!您可以在下面看到它的实际效果。

2023-11-27 21-40-09.2023-11-27 21_40_53.gif

由于 animation-timeline 属性仍处于实验阶段,因此并非所有浏览器(准确地说是 FirefoxSafari)都支持它。

您可以检查浏览器的兼容性并据此使用。

http://www.lryc.cn/news/257804.html

相关文章:

  • 深度剖析中国居民消费价格指数CPI数据可视化案例-Python可视化技术实现(附完整源码)【数据可视化项目案例-16】
  • SpringBoot——嵌入式 Servlet容器
  • 王炸升级!PartyRock 10分钟构建 AI 应用
  • 文件管理和操作工具Path Finder mac功能介绍
  • 转换 pytorch 格式模型为 caffe格式模型 pth2caffemodel
  • 【S32DS RTD实战】-1.3-S32K3工程生成S19,BIN,Hex文件,以及Post-build steps的妙用
  • Java工程找不到javax.xml.bind.annotation包
  • 【C语言】网络字节序和主机字节序
  • 极简模式,助力宏观数据监控
  • 智能优化算法应用:基于花授粉算法3D无线传感器网络(WSN)覆盖优化 - 附代码
  • IT圈的“鄙视链”大揭秘:从Java到Go,编程语言之战!
  • 【C++】算法库(复制操作、交换操作、变换操作)
  • CV计算机视觉每日开源代码Paper with code速览-2023.12.6
  • 面试经典150题(1-2)
  • MySQL使用教程
  • 微服务学习:Ribbon实现客户端负载均衡,将请求分发到多个服务提供者
  • 孩子还是有一颗网安梦——Bandit通关教程:Level0
  • 读excel文件,借助openpyxl工具
  • ubuntu16.04升级openssl
  • 【力扣100】56.合并区间
  • 重磅!2023中国高校计算机大赛-人工智能创意赛结果出炉
  • [Linux] 用LNMP网站框架搭建论坛
  • 记录 | 使用samba将ubuntu文件夹映射到windows实现共享文件夹
  • leetcode 股票DP系列 总结篇
  • 深入理解Java虚拟机---对象的创建和内存异常溢出
  • windows MYSQL解决中文乱码问题
  • EasyRecovery2024免费永久版手机数据恢复软件
  • 2023/12/11 作业
  • 【11】Qt Designer
  • 【算法优选】 动态规划之路径问题——贰