这个应该是已经有不少人作过的东西,我应该只是算手痒,想写一下,因此,花了点时间折腾了这个,顺便把 Dark Mode 的处理也加上了。css
首先能够很明确的一点,这个真没技术含量存在,只是须要点耐心。 html
LED 数字包含了左右各两条线,中间三条线,一共 7 条线。因此,为了可以更容易辨识,在写 demo 的时候,我直接这样写了。git
<div class="digital digital_0"> <span class="c1"></span> <span class="c2"></span> <span class="c3"></span> <span class="l1"></span> <span class="l2"></span> <span class="r1"></span> <span class="r2"></span> </div>
至于 digital_0
这个的做用,其实很简单,就是控制从 0 ~ 9 这十个数字的变化而存在的。优化
.digital_1 .c1, .digital_1 .c2, .digital_1 .c3, .digital_1 .l1, .digital_1 .l2, .digital_2 .l1, .digital_2 .r2, .digital_3 .l1, .digital_3 .l2, .digital_4 .c1, .digital_4 .c3, .digital_4 .l2, .digital_5 .l2, .digital_5 .r1, .digital_6 .r1, .digital_7 .c2, .digital_7 .c3, .digital_7 .l1, .digital_7 .l2, .digital_9 .l2, .digital_0 .c2 { animation: changeDigital 200ms 0ms 1 ease-in forwards; }
这里使用了一个 animation 动画,而且时间是 200ms
,主要是为了让某些部分消失的时候,有一个过渡效果。动画
@keyframes changeDigital { form { opacity: 1; } to { opacity: 0; } }
那么剩下来的就是最须要耐心的地方了,调整控制那 7 条线的位置,同时还要考虑每条线是带有斜角的,并且还稍微有点圆弧的感受。带点圆弧的感受那么直接使用 border-radius
就能够了,至于那个斜角的话,若是各位知道 CSS 中用边框画三角的方法,那么就应该明白怎么作这个斜角了。spa
当咱们要画三角的时候,width
和 height
都是为 0
,而后用过控制 border-width
而获得最终的三角的大小,那么这里若是咱们根据线条的位置,适当选择 width
和 height
有具体的值,是否是就有斜角的感受了呢。code
接着,须要注意横着的中间那根线,也就是 .c2
这个元素,线条两边是三角突出的,能够实现的方式也不少,这里我选择使用 :after
和 :before
相叠加。orm
最后就是对每一个元素的位置作调整,控制好大小位置就能够了,由于是使用定位的方式来操做,因此,调整起来仍是很简单的。htm
.digital span { position: absolute; border-radius: 50vh; box-sizing: border-box; } .digital .c1, .digital .c2, .digital .c3 { height: 0; width: 26px; border-left: 4px solid transparent; border-right: 4px solid transparent; } .digital .c1 { top: 0; left: 0; border-top: 4px solid currentColor; } .digital .c2 { top: 50%; left: 0; margin-top: -2px; } .digital .c2:before, .digital .c2:after { content: ""; height: 0; width: 24px; border-left: 2px solid transparent; border-right: 2px solid transparent; box-sizing: border-box; } .digital .c2:before { position: absolute; top: 0; left: -3px; border-bottom: 2px solid currentColor; } .digital .c2:after { position: absolute; top: 2px; left: -3px; border-top: 2px solid currentColor; } .digital .c3 { bottom: 0; left: 0; border-bottom: 4px solid currentColor; } .digital .l1, .digital .l2 { height: 21px; width: 0; left: 0; border-top: 2px solid transparent; border-bottom: 2px solid transparent; border-left: 4px solid currentColor; } .digital .l1 { top: 1px; border-top-width: 4px; } .digital .l2 { top: 24px; border-bottom-width: 4px; } .digital .r1, .digital .r2 { height: 21px; width: 0; right: 0; border-top: 2px solid transparent; border-bottom: 2px solid transparent; border-right: 4px solid currentColor; } .digital .r1 { top: 1px; border-top-width: 4px; } .digital .r2 { top: 24px; border-bottom-width: 4px; }
作完这些,剩下的就是简单的对外层元素作点优化,好比稍微倾斜一点。blog
.digital { position: relative; width: 26px; height: 46px; margin-left: 10px; transform: skew(-6deg); }
哦,忘了说了,这里的边框颜色我选择使用 currentColor
的方式,这样能够在暗黑模式切换的过程当中,只须要修改 body
中的文字颜色和背景色就能够了。currentColor
会选择文字颜色来使用。
样式处理完以后,接着就是添加点 JS 来显示时钟了,这个没啥好说的,只要把两个数字整出来放到不一样的 div
中就行了。这里我取个位数的时候,是用 m%10
的方式取余;取十位数的时候是经过 parseInt(m/10)
的方式取整。取出来以后分别放到想对应的 div
中就 ok 了。
demo地址:http://lab.tianyizone.com/demo/digital_number.html