css31个简单的 LED 数据数字时钟完成方式

日期:2021-02-28 类型:科技新闻 

关键词:小程序制作流程,抽奖小程序,微信小程序怎么开店,小程序码生成,小程序模版

这个应当是早已有许多人做过的物品,我应当只是算手痒,想写1下,因此,花了点時间折腾了这个,顺带把 Dark Mode 的解决也再加了。

最先能够很确立的1点,这个真没技术性含量存在,只是必须点细心。

LED 数据包括了上下各两条线,正中间3条线,1共 7 条线。因此,以便可以更非常容易辨识,在写 demo 的情况下,我立即这样写了。

<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 这10个数据的转变而存在的。

.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;
}

这里应用了1个 animation 动漫,而且時间是 200ms,关键是以便让一些一部分消退的情况下,有1个过渡实际效果。

@keyframes changeDigital {
  form {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

那末剩余来的便是最必须细心的地区了,调剂操纵那 7 条线的部位,另外还要考虑到每条线是带有斜角的,并且还略微有点圆弧的觉得。带点圆弧的觉得那末立即应用 border-radius 便可以了,至于那个斜角的话,假如各位了解 CSS 选用边框画3角的方式,那末就应当搞清楚如何做这个斜角了。

当大家要画3角的情况下,width 和 height 全是为 0,随后用过操纵 border-width 而获得最后的3角的尺寸,那末这里假如大家依据线条的部位,适度挑选 width 和 height 有实际的值,是否就有斜角的觉得了呢。

接着,必须留意横着的正中间那根线,也便是 .c2 这个元素,线条两侧是3角突显的,能够完成的方法也许多,这里我挑选应用 :after 和 :before 相叠加。

最终便是对每一个元素的部位做调剂,操纵好尺寸部位便可以了,由于是应用精准定位的方法来实际操作,因此,调剂起来還是很简易的。

.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: ⑵px;
}
.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: ⑶px;
  border-bottom: 2px solid currentColor;
}
.digital .c2:after {
  position: absolute;
  top: 2px;
  left: ⑶px;
  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;
}

做完这些,剩余的便是简易的对外层元素做点提升,例如略微歪斜1点。

.digital {
  position: relative;
  width: 26px;
  height: 46px;
  margin-left: 10px;
  transform: skew(⑹deg);
}

哦,忘了说了,这里的边框色调我挑选应用 currentColor 的方法,这样能够在黯黑方式切换的全过程中,只必须改动 body 中的文本色调和情况色便可以了。currentColor 会挑选文本色调来应用。

款式解决完以后,接着便是加上点 JS 来显示信息数字时钟了,这个没啥好说的,要是把两个数据整出来放到不一样的 div 中就行了。这里我取个位数的情况下,是用 m%10 的方法取余;取10位数的情况下是根据 parseInt(m/10) 的方法取整。取下来以后各自放到想对应的 div 中就 ok 了。

demo详细地址:http://lab.tianyizone.com/demo/digital_number.html

以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。