当前位置: 首页
前端开发
纯CSS实现炫酷文本时钟特效

纯CSS实现炫酷文本时钟特效

热心网友 时间:2026-04-28
转载

纯CSS文本时钟:一场关于时间的视觉艺术

眼前这个效果,可不是你熟悉的那种带有时针分针的圆盘时钟。它没有表盘,也没有密密麻麻的分钟刻度。时间,在这里被“读”了出来。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

它的原理是让当前时间以高亮文本的形式呈现,显示精度在5分钟左右,误差大约正负4分钟。界面上所有字母构成了一个正方形矩阵,其中该高亮的单词鲜艳夺目,其余字母则色调偏暗,共同营造出一种独特的科技美学。

最有趣的地方在于,这个看似动态变化的时钟,其核心驱动几乎完全由CSS完成。Ja vaScript只在一开始负责获取一个初始时间(如果页面由服务端渲染,这一步甚至可以省略),之后的所有“跳动”都交给了样式表。整个实现主要围绕以下几个亮点展开:

  • 整体布局:所有英文单词被精心排列成一个正方形。有些字母本身并不表示时间,它们存在的意义只是为了“撑起”这个完美的方形布局。
  • 时间粒度:时间的更新并非每分钟一次,而是以5分钟为基本单位进行“跳跃”,用“FIVE”、“TEN”、“QUARTER”这样的单词来表征分钟。
  • 视觉焦点:通过颜色对比,瞬间突出当前时刻需要亮起的单词。
  • 零定时器:完全不需要Ja vaScript设置定时器来推动时间变化,仅靠CSS动画就能实现永不停歇的运转。

实现过程

这个时钟的设计哲学很明确:用文字本身来诉说时间。钟面上的每个字母都对应着一个特定的时间节点。比如,“TEN”、“QUARTER”、“HALF”用来指示分钟数,而下方排列的“ONE”、“TWO”、“THREE”等则代表小时。这种设计巧妙地避开了数字的冰冷,赋予时间一种叙事般的创意表达。

界面布局

首先来看看HTML结构。布局的首要目标是让每一行的文本长度保持一致。因此,当表示时间的单词长度不够时,就需要加入一些“填充字符”——那些永远不会被高亮的字母。它们就像是舞台的背景板,只为衬托主角而存在。

纯CSS实现炫酷文本时钟特效

可以从下面这段部分代码中窥见一斑。只有被p标签包裹的才是真正会参与高亮变化的时间单词:

F O U R

Y

F I V E

T W O


E I G H T

C

E L E V E N


S E V E N

D

T W E L V E


CSS样式

观察上面的HTML代码,你会发现p标签的class名称很有规律。hour代表小时,后面的h0h11分别对应12个钟点。分钟则由min表示,并且因为以5分钟为间隔,所以会出现m5m15m25这样的类名。此外,为了表达“几点过几分”或“差几分到几点”的概念,还定义了类似下面这样的关键元素:

Q U A R T E R

H A L F

T O

P A S T

动画实现

这一部分是整个项目的精髓所在:如何在不使用Ja vaScript的情况下,让单词自动且准确地变化?答案全在CSS动画里。为了更高效地管理复杂的样式逻辑,这里借助了Sass预处理器。

首先,定义一些核心变量。比如高亮色、暗色,以及一个代表一小时总秒数的变量(调试时可以通过调小这个值来观察时钟加速运行的效果):

$current: #dddd55;$disable: rgba(0,0,0,0.5);$time: 3600s;

接着,通过@keyframes定义一系列控制颜色变化的动画。这里的技巧在于,将具有相同高亮逻辑的时间点分组到同一个动画关键帧中。例如:

@keyframes m0m30 {}@keyframes m5m25m35m55 {}@keyframes m10m50 {}@keyframes m20m25m35m40 {}@keyframes m15m45 {}.m0, .m30 {  animation: infinite m0m30 step-end $time;}.m5 {  animation: infinite m5m25m35m55 step-end $time;}.m15, .m45 {  animation: infinite m15m45 step-end $time;}

那么,如何确定每个单词在何时高亮呢?这就依赖一个至关重要的CSS属性:animation-delay(动画延迟)。原作者使用了一段巧妙的Sass循环,为每个可能的时间点(以5分钟为步长)计算出精确的延迟值:

$k: 0;@while $k < 60 {  .minute#{$k} {    $l: 0;    @while $l < 60 {      .m#{$l} {        animation-delay: - $time * $k / 60;      }      $l: $l + 5;    }    .before,    .after { animation-delay: -$time * $k / 60; }    .m30 { animation-delay: $time/2 - $time * $k / 60; }    @for $i from 0 through 11 {      &.hour#{$i} {        @for $j from 0 through 11 {          .h#{$j} { animation-delay: (-$time*5/12 + $time*($j - $i)) -  ($time * $k / 60); }        }      }    }  }  $k: $k + 5;}

简单来说,这段代码通过嵌套循环,动态生成了对应不同分钟($k)和小时($i, $j)场景下的CSS类,并为每个类设置了经过精密计算的animation-delay。正是这些差异化的延迟时间,像一组编好程序的齿轮,驱动着整个文本矩阵在正确的时间点亮正确的单词,从而模拟出时钟的运转。

最后

以上便是利用纯CSS打造一个文本时钟的全过程解析。这个项目远不止是一个计时工具,它更像是一个展示前端开发者如何用代码进行创意表达的绝佳案例。通过深度挖掘CSS动画的潜力,并借助Sass进行逻辑抽象,我们完全可以在不依赖脚本的情况下,实现如此复杂且富有美感的动态视觉效果。这无疑为前端技术的创造性应用,打开了又一扇想象之门。

来源:https://www.jb51.net/css/912600.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
禁止HTML页面滚动的操作方法

禁止HTML页面滚动的操作方法

在前端开发中,禁止HTML页面滚动通常涉及到对CSS样式或Ja vaScript的使用。以下是一些常见的方法: 1 使用CSS的overflow属性 最直接的思路,是通过设置HTML或body元素的 overflow 属性为 hidden 来禁止滚动。这么一来,任何超出视口的内容都会被隐藏,滚动的

时间:2026-04-28 17:41
uni-app怎么做类似于淘宝的物流时间轴 uni-app步骤条组件定制实现【实战】

uni-app怎么做类似于淘宝的物流时间轴 uni-app步骤条组件定制实现【实战】

uni-app 里用 u-steps 实现物流时间轴,为什么总对不上实际节点? 问题根源很明确:你把一个设计用于「线性流程」的步骤条,硬生生套在了「异步事件流」的物流场景上。这就像试图用整齐划一的阅兵方阵,去展示一场状况百出的越野赛跑。 淘宝的物流时间轴,本质上是一系列独立事件的集合。每个节点都有自

时间:2026-04-28 17:41
如何用 JavaScript 实现用户输入五个姓名并按顺序显示在网页上

如何用 JavaScript 实现用户输入五个姓名并按顺序显示在网页上

如何用 prompt() 收集五个姓名并动态渲染到页面?一份实战指南 在前端入门的实践环节里,有一个“经典关卡”:如何从用户那里收集一组数据,存起来,再漂亮地展示出来?听起来基础,但很多新手在第一关就卡住了——变量作用域混乱、DOM元素找不到、代码逻辑“断层”,这些都是常见问题。 今天,我们就以“收

时间:2026-04-28 17:41
关于html选择框创建占位符的问题

关于html选择框创建占位符的问题

为HTML选择框(Select)添加“占位符”的几种思路 在表单设计中,为文本输入框设置一个灰色的提示占位符(placeholder)早已是标准操作,用户体验非常好。但轮到下拉选择框(Select)时,不少开发者会发现事情没那么简单——HTML原生并没有提供类似的placeholder属性。 最直观

时间:2026-04-28 17:40
uni-app怎么隐藏导航栏 uni-app自定义顶部导航栏配置【详解】

uni-app怎么隐藏导航栏 uni-app自定义顶部导航栏配置【详解】

uni-app导航栏隐藏的真相:一份跨端开发的避坑指南 先直接说结论,这也是很多人试错过后的经验:na vigationBarHidden: true 确实是写法最简单、跨端最稳妥的隐藏方式,但它的生效范围仅限于小程序和H5。想在APP端真正移除原生导航栏?那必须祭出组合拳:na vigationS

时间:2026-04-28 17:40
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程