CSS实现阮大佬博文的阅读进度功能

简介: CSS实现阮大佬博文的阅读进度功能

🎄 前言


小包在学习阮一峰大佬的《ES6入门教程》时,对文章顶部的阅读进度功能产生了浓厚的兴趣。小包当时猜想应该是使用 JavaScript 实现的,但最近爱上了浩如烟海的 CSS ,于是小包有个大胆的想法,单纯的 CSS 能实现阅读进度功能吗?


能,不止能,还非常巧妙!CSS⭐CSS⭐CSS 真的太强了。


虽然通过 CSS 可以实现阅读进度问题,但 JavaScript 作为老本行,一样得精通。

因此学习本文,你可以学会:


  • 使用 JavaScript 实现阅读进度功能
  • 使用 CSS 实现阅读进度功能


🔥 利用JavaScript实现阅读进度


📃 HTML与CSS


html css 部分非常简单,通过嵌套的两个 div 实现,外部的 div 提供底色背景,内部 div 显示阅读进度


<div class="read_pro">
    <div class="read_pro_inner"></div>
</div>
复制代码
.read_pro {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #DDD;
}
.read_pro_inner {
    content: '';
    position: absolute;
    left: 0;
    height: 100%;
    background-color: #0089f2;
}
复制代码


当我们设置 .read_pro_inner 的宽度为 20% 时,得到的效果图如下:


image.png

只截取部分图,并放大了浏览器,要不灰色部分会非常长


台子搭好了,下面就是通过 js 来动态计算 read_pro_innerwidth 即可。


🎬 JS实现


如果我们利用 JavaScript 来实现阅读进度,我们要获取到文档的总高度、文档滚动距离、浏览器窗口的可视高度。


  • 文档总高度: document.documentElement.scrollHeight
  • 窗口可视高度: document.documentElment.cliengHeight
  • 滚动距离: document.documentElement.scrollTop || document.body.scrollTop


光看上面三个属性的名字有几分难以理解,来看一张示意图

image.png


从上图可以看到 scrollTop 就是已经读过被卷起来的文档部分,scrollHeight 是文档的总长度,clientHeight 是浏览器显示区域的高度


图源: 慕课手记


获取上面几个属性值后,阅读进度就可以通过下面的公式计算出来


readProInner.style.width = +(scrollTop / (scrollHeight- clientHeight)).toFixed(2)*100 + '%'
复制代码


大家可能会有疑惑,为什么分母是 scrollHeight- clientHeight 而不是 scrollHeight?


当滚动条滚动到底部时,浏览器此时仍显示一屏内容,此时滚动条无法再滚动,scrollTop 无法再增加,因此 scrollTop 的最大值是 scrollHeight- clientHeight ,如果使用 scrollHeight 做分母,阅读进度最终无法达到 100%


document.addEventListener('scroll', function(e) {
    const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
    readProInner.style.width = +(scrollTop/(scrollHeight-clientHeight)).toFixed(2)*100 + '%'
})
复制代码


使用 js 实现需要监听 scroll 事件,而且滚动时有可能是频繁的 scroll 事件触发,有可能会造成一定的性能浪费,所以我们来一起学习 css 实现方案


🌟 使用CSS实现阅读进度


使用 CSS 实现阅读进度的方法很有意思,而且非常巧妙,不多说了,一起来看看。


📕预备知识


  1. linear-gradient: 线性渐变,第一个参数为渐变方向,后面是颜色比例变化。
    比如设置 linear-gradient(to right top, #0089f2 50%, #DDD 50%)
    就可以实现下面效果,一个蓝色的三角形:


image.png


看到这种蓝色的三角形,你有没有感觉离阅读进度已经很近了?


如果我们用一块白块遮住蓝块,只留一条缝在顶部,那当前显示出来蓝色块的底边不就是阅读进度吗?

image.png


最后处理最后一屏的问题,保证滚动条滚动至底部时,阅读进度到达 100%

image.png


这里如果没能理解原理,不用急,后面我会更详细的演示


  1. @supports


类似于 js 的功能检查,可以检查 CSS 中某一属性或功能当前浏览器是否支持。


💡 实现原理


上面讲解 linear-height 时,我们提出了一种实现方案: 使用一块白块遮住蓝块,只留一条缝在顶部,显示的蓝条长度就是阅读进度


光说不难假把式,为了方便大家理解原理,我们使用一个案例来模拟一下,蓝块仍保持原来大小,使用一块 0.8 透明度的黑块盖在上面,黑块给蓝块在顶部空出 10px 空间。具体看下面演示

image.png


现在是不是感觉瞬间茅塞顿开


💻 CSS实现


  1. 首先使用 linear-gradient 实现蓝色背景块,并且要空出最后一屏


body{ 
    background: linear-gradient(to right top, #0089f2 50%, #DDD 50%);
    /* 通过 calc 函数配合 100vh 就可以从总长中删除一屏的高度 */
    /* 100vh 浏览器视口的高度 */
    background-size: 100% calc(100% - 100vh + 4px);
    background-repeat: no-repeat;
}
复制代码


  1. 设置盖住蓝块的白块


阅读进度条的高度为 3px ,因此设置白块的高度为 100% - 3px,可以另外加一个 div 元素来设置白块,但小包推荐使用为元素 :before/:after ,伪元素不在文档流之中,方便渲染和控制


body:before{
    content:'';
    /* fixed定位 */
    position: fixed;
    /* 同时设置 top 和 bottom 可以拉伸 height */
    /* 设置高度为 100% - 3px */
    top: 3px;
    bottom: 0;
    width: 100%;
    /* 降低层级,白块显示在文字之下 */
    z-index: -1;
    background: white;
}
复制代码


通过上面简单的代码,就可以实现封面阅读进度效果了,撒花~~~~


🛕 源码仓库


传送门: 阅读进度功能

如果感觉有帮助的话,别忘了给小包点个 ⭐ 。


相关文章
|
前端开发
CSS权威指南阅读笔记第五章01
CSS权威指南阅读笔记第五章01
|
21天前
|
存储 前端开发 开发者
深入了解 Sass 和 SCSS:CSS 预处理器的强大功能
Sass(Syntactically Awesome Stylesheets)是一个强大的 CSS 预处理器,为开发者提供了诸多高级特性,如变量、嵌套、混合、继承等,简化了 CSS 的编写和管理。SCSS 是 Sass 3 引入的新语法,完全兼容 CSS3,并增强了 Sass 的动态功能。本文详细介绍了 Sass 和 SCSS 的核心特性及其在实际开发中的应用,如变量定义、嵌套规则、混合、继承、以及常用的操作符与扩展功能。
23 0
|
4月前
|
前端开发
前端 CSS 经典:水波进度样式
前端 CSS 经典:水波进度样式
64 0
|
5月前
|
前端开发 JavaScript 容器
技术经验解读:个人练习:使用HTML+CSS3制作图片轮播功能(不使用JavaScript)
技术经验解读:个人练习:使用HTML+CSS3制作图片轮播功能(不使用JavaScript)
64 0
|
6月前
|
存储 JavaScript 前端开发
笔.COOL,一个功能完备、使用便捷的在线HTML/CSS/JS以及Vue编辑器和作品分享平台
笔.COOL是一个新兴的在线 HTML/CSS/JS 及 Vue 编辑器,提供实时预览和云端存储功能。用户可以随时随地编写和保存代码,同时分享作品给他人预览和学习。它也是一个实用的 BUG 复现工具,支持嵌入编辑器到博客,促进代码交流。社区活跃,适合开发者展示作品、获取灵感和学习。
|
6月前
|
小程序 前端开发 JavaScript
使用CSS的媒体查询功能在小程序中实现自适应布局
使用CSS的媒体查询功能在小程序中实现自适应布局
|
6月前
|
前端开发
购物车的功能——CSS源码
购物车的功能——CSS源码
|
6月前
html+css+js完成代码弹出功能
html+css+js完成代码弹出功能
51 0
|
6月前
|
前端开发 容器
前端知识笔记(二十七)———CSS核心功能手册:从熟悉到精通
前端知识笔记(二十七)———CSS核心功能手册:从熟悉到精通
51 0
|
6月前
|
前端开发 容器
前端知识笔记(三)———CSS核心功能手册:从熟悉到精通
前端知识笔记(三)———CSS核心功能手册:从熟悉到精通
50 0