欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

  發(fā)布時(shí)間:2020-01-15 16:33:34   作者:林小志   我要評(píng)論
這篇文章主要介紹了css3一個(gè)簡(jiǎn)易的 LED 數(shù)字時(shí)鐘實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

這個(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)文章

最新評(píng)論