十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
使用css3怎么實現(xiàn)一個LED 數(shù)字時鐘?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

css是一種用來表現(xiàn)HTML或XML等文件樣式的計算機語言,主要是用來設(shè)計網(wǎng)頁的樣式,使網(wǎng)頁更加美化。它也是一種定義樣式結(jié)構(gòu)如字體、顏色、位置等的語言,并且css樣式可以直接存儲于HTML網(wǎng)頁或者單獨的樣式單文件中,而樣式規(guī)則的優(yōu)先級由css根據(jù)這個層次結(jié)構(gòu)決定,從而實現(xiàn)級聯(lián)效果,發(fā)展至今,css不僅能裝飾網(wǎng)頁,也可以配合各種腳本對于網(wǎng)頁進行格式化。
至于 digital_0 這個的作用,其實很簡單,就是控制從 0 ~ 9 這十個數(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;
}這里使用了一個 animation 動畫,并且時間是 200ms,主要是為了讓某些部分消失的時候,有一個過渡效果。
@keyframes changeDigital {
form {
opacity: 1;
}
to {
opacity: 0;
}
}那么剩下來的就是最需要耐心的地方了,調(diào)整控制那 7 條線的位置,同時還要考慮每條線是帶有斜角的,而且還稍微有點圓弧的感覺。帶點圓弧的感覺那么直接使用 border-radius 就可以了,至于那個斜角的話,如果各位知道 CSS 中用邊框畫三角的方法,那么就應(yīng)該明白怎么做這個斜角了。
當(dāng)我們要畫三角的時候,width 和 height 都是為 0,然后用過控制 border-width 而得到最終的三角的大小,那么這里如果我們根據(jù)線條的位置,適當(dāng)選擇 width 和 height 有具體的值,是不是就有斜角的感覺了呢。
接著,需要注意橫著的中間那根線,也就是 .c2 這個元素,線條兩邊是三角突出的,可以實現(xiàn)的方式也很多,這里我選擇使用 :after 和 :before 相疊加。
最后就是對每個元素的位置做調(diào)整,控制好大小位置就可以了,因為是使用定位的方式來操作,所以,調(diào)整起來還是很簡單的。
.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;
}做完這些,剩下的就是簡單的對外層元素做點優(yōu)化,比如稍微傾斜一點。
.digital {
position: relative;
width: 26px;
height: 46px;
margin-left: 10px;
transform: skew(-6deg);
}看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,的支持。