如何实现页面顶部, 自定义滚动进度条样式

yumo6667个月前 (04-23)技术文章35

关键词:自定义滚动条、自定义顶部滚动条

要实现页面顶部的自定义滚动进度条样式,可以按照以下步骤进行:

  1. 在HTML中添加滚动进度条的容器元素,通常可以使用一个元素作为容器,放在页面顶部的合适位置。
<div id="scroll-progress"></div>
  1. 在CSS中定义滚动进度条的样式。可以使用背景颜色、高度、透明度等属性来自定义样式。
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background-color: #f00; /* 自定义进度条颜色 */
  opacity: 0.7; /* 自定义进度条透明度 */
  z-index: 9999; /* 确保进度条显示在最顶层 */
}
  1. 使用JavaScript来监听页面滚动事件,并更新滚动进度条的宽度。
var scrollProgress = document.getElementById('scroll-progress');
var requestId;

function updateScrollProgress() {
  var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
  var scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight;
  var progress = (scrollTop / (scrollHeight - window.innerHeight)) * 100;
  scrollProgress.style.width = progress + '%';
  requestId = null;
}

function scrollHandler() {
  if (!requestId) {
    requestId = requestAnimationFrame(updateScrollProgress);
  }
}

window.addEventListener('scroll', scrollHandler);

以上就是一个简单的实现页面顶部自定义滚动进度条样式的方法。根据自己的需求,可以调整CSS样式和JavaScript的逻辑来实现不同的效果。

完整代码:

<!DOCTYPE html>
<html>
<head>
  <title>自定义滚动进度条样式</title>
  <style>
      #scroll-progress {
          position: fixed;
          top: 0;
          left: 0;
          width: 100%;
          height: 5px;
          background-color: #f00; /* 自定义进度条颜色 */
          opacity: 0.7; /* 自定义进度条透明度 */
          z-index: 9999; /* 确保进度条显示在最顶层 */
      }
  </style>
</head>
<body>
<div id="scroll-progress"></div>

<!-- 假设有很长的内容 -->
<div style="height: 2000px;"></div>

<script>
  var scrollProgress = document.getElementById('scroll-progress');
  var requestId;

  function updateScrollProgress() {
    var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
    var scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight;
    var progress = (scrollTop / (scrollHeight - window.innerHeight)) * 100;
    scrollProgress.style.width = progress + '%';
    requestId = null;
  }

  function scrollHandler() {
    if (!requestId) {
      requestId = requestAnimationFrame(updateScrollProgress);
    }
  }

  window.addEventListener('scroll', scrollHandler);
</script>
</body>
</html>

相关文章

小程序学习日志7:可滚动的视图区域组件(滚动条)

导读经过这段日子的学习,大家对小程序的了解多了多少呢?我们这段时间学了很多组件的用法,以及这些组件的属性和属性的合法值,图片、文字、块,还了解了不少的样式代码和小程序的基本知识。我们今天来讲一个可滚动...

selenium:操作滚动条的方法(8)

selenium支持几种操作滚动条的方法,主要介绍如下:使用ActionChains 类模拟鼠标滚轮操作使用函数ActionChains.send_keys发送按键Keys.PAGE_DOWN往下滑动...

网页背景全屏就这?分享 1 段优质 CSS 代码片段!

大家好,我是大澈!本文约 700+ 字,整篇阅读约需 1 分钟。每日分享一段优质代码片段。今天分享一段 CSS 代码片段,使用 CSS 设置网页全屏背景图片,很简单。老规矩,先阅读代码片段并思考,再看...

实战网页实现平滑滚动

在导航中,我们使用#简单的实现了,现在我们要实现,点击导航自动跳转指定的节去,通过id去选择<ul class="main-nav-list"> <...

10款流行的Markdown编辑器

1、 用户能借助键盘快捷键或工具栏按钮应用及删除 Markdown 格式。MarkdownPad 的左右栏分隔设计,可让用户实时查看以 HTML 格式呈现的 Markdown 文档效果。2、 WMD3...