css3一個(gè)簡(jiǎn)易的 LED 數(shù)字時(shí)鐘實(shí)現(xiàn)方法

這個(gè)應(yīng)該是已經(jīng)有很多人做過(guò)的東西,我應(yīng)該只是算手癢,想寫(xiě)一下,所以,花了點(diǎn)時(shí)間折騰了這個(gè),順便把 Dark Mode 的處理也加上了。
首先可以很明確的一點(diǎn),這個(gè)真沒(méi)技術(shù)含量存在,只是需要點(diǎn)耐心。
LED 數(shù)字包含了左右各兩條線(xiàn),中間三條線(xiàn),一共 7 條線(xiàn)。所以,為了能夠更容易辨識(shí),在寫(xiě) demo 的時(shí)候,我直接這樣寫(xiě)了。
<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 這個(gè)的作用,其實(shí)很簡(jiǎn)單,就是控制從 0 ~ 9 這十個(gè)數(shù)字的變化而存在的。
.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; }
這里使用了一個(gè) animation 動(dòng)畫(huà),并且時(shí)間是 200ms,主要是為了讓某些部分消失的時(shí)候,有一個(gè)過(guò)渡效果。
@keyframes changeDigital { form { opacity: 1; } to { opacity: 0; } }
那么剩下來(lái)的就是最需要耐心的地方了,調(diào)整控制那 7 條線(xiàn)的位置,同時(shí)還要考慮每條線(xiàn)是帶有斜角的,而且還稍微有點(diǎn)圓弧的感覺(jué)。帶點(diǎn)圓弧的感覺(jué)那么直接使用 border-radius 就可以了,至于那個(gè)斜角的話(huà),如果各位知道 CSS 中用邊框畫(huà)三角的方法,那么就應(yīng)該明白怎么做這個(gè)斜角了。
當(dāng)我們要畫(huà)三角的時(shí)候,width 和 height 都是為 0,然后用過(guò)控制 border-width 而得到最終的三角的大小,那么這里如果我們根據(jù)線(xiàn)條的位置,適當(dāng)選擇 width 和 height 有具體的值,是不是就有斜角的感覺(jué)了呢。
接著,需要注意橫著的中間那根線(xiàn),也就是 .c2 這個(gè)元素,線(xiàn)條兩邊是三角突出的,可以實(shí)現(xiàn)的方式也很多,這里我選擇使用 :after 和 :before 相疊加。
最后就是對(duì)每個(gè)元素的位置做調(diào)整,控制好大小位置就可以了,因?yàn)槭鞘褂枚ㄎ坏姆绞絹?lái)操作,所以,調(diào)整起來(lái)還是很簡(jiǎn)單的。
.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; }
做完這些,剩下的就是簡(jiǎn)單的對(duì)外層元素做點(diǎn)優(yōu)化,比如稍微傾斜一點(diǎn)。
.digital { position: relative; width: 26px; height: 46px; margin-left: 10px; transform: skew(-6deg); }
哦,忘了說(shuō)了,這里的邊框顏色我選擇使用 currentColor 的方式,這樣可以在暗黑模式切換的過(guò)程中,只需要修改 body 中的文字顏色和背景色就可以了。currentColor 會(huì)選擇文字顏色來(lái)使用。
樣式處理完之后,接著就是添加點(diǎn) JS 來(lái)顯示時(shí)鐘了,這個(gè)沒(méi)啥好說(shuō)的,只要把兩個(gè)數(shù)字整出來(lái)放到不同的 div 中就好了。這里我取個(gè)位數(shù)的時(shí)候,是用 m%10 的方式取余;取十位數(shù)的時(shí)候是通過(guò) parseInt(m/10) 的方式取整。取出來(lái)之后分別放到想對(duì)應(yīng)的 div 中就 ok 了。
demo地址:http://lab.tianyizone.com/demo/digital_number.html
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
純CSS3實(shí)現(xiàn)運(yùn)行時(shí)鐘的示例代碼
這篇文章主要介紹了純CSS3如何實(shí)現(xiàn)運(yùn)行的時(shí)鐘,幫助大家更好的制作CSS3特效,美化網(wǎng)頁(yè),感興趣的朋友可以了解下。2021-01-25css3 利用transform打造走動(dòng)的2D時(shí)鐘
這篇文章主要介紹了css3 利用transform打造走動(dòng)的2D時(shí)鐘,幫助大家更好的利用cSS3制作特效,美化自身網(wǎng)頁(yè),感興趣的朋友可以了解下2020-10-20利用CSS3 動(dòng)畫(huà) 繪畫(huà) 圓形動(dòng)態(tài)時(shí)鐘
這篇文章主要介紹了利用CSS3 動(dòng)畫(huà) 繪畫(huà) 圓形動(dòng)態(tài)時(shí)鐘的相關(guān)資料,需要的朋友可以參考下2018-03-20CSS實(shí)現(xiàn)漂亮的時(shí)鐘動(dòng)畫(huà)效果的實(shí)例代碼
這篇文章主要介紹了CSS實(shí)現(xiàn)漂亮的時(shí)鐘動(dòng)畫(huà)效果的實(shí)例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-29