温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

CSS3中如何实现倒计时效果

发布时间:2021-03-16 15:26:53 阅读:548 作者:小新 栏目:web开发

小编给大家分享一下CSS3中如何实现倒计时效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

实现效果

CSS3中如何实现倒计时效果

实现代码

html

<div class='wrapper'>
  <div class='time-part-wrapper'>
    <div class='time-part minutes tens'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
    <div class='time-part minutes ones'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>9</span>
        <span class='digit'>8</span>
        <span class='digit'>7</span>
        <span class='digit'>6</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
  </div>
  <div class='time-part-wrapper'>
    <div class='time-part seconds tens'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
    <div class='time-part seconds ones'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>9</span>
        <span class='digit'>8</span>
        <span class='digit'>7</span>
        <span class='digit'>6</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
  </div>
  <div class='time-part-wrapper'>
    <div class='time-part hundredths tens'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>9</span>
        <span class='digit'>8</span>
        <span class='digit'>7</span>
        <span class='digit'>6</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
    <div class='time-part hundredths ones'>
      <div class='digit-wrapper'>
        <span class='digit'>0</span>
        <span class='digit'>9</span>
        <span class='digit'>8</span>
        <span class='digit'>7</span>
        <span class='digit'>6</span>
        <span class='digit'>5</span>
        <span class='digit'>4</span>
        <span class='digit'>3</span>
        <span class='digit'>2</span>
        <span class='digit'>1</span>
        <span class='digit'>0</span>
      </div>
    </div>
  </div>
</div>

css

/* Play with speed and easing of the animation */
/* =========================================== */
.digit {
  display: inline-block;
  font-size200px;
  colorrgba(0000.25);
  height180px;
  line-height1;
}

.time-part-wrapper {
  display: inline-block;
  margin-right50px;
  position: relative;
}
.time-part-wrapper:not(:last-child):after {
  content":";
  display: block;
  width30px;
  height230px;
  position: absolute;
  top0px;
  right: -30px;
  colorrgba(0000.25);
  font-size200px;
  line-height0.9;
}

.time-part {
  width140px;
  text-align: center;
  height180px;
  overflow: hidden;
  display: inline-block;
  margin-left: -5px;
  box-sizing: border-box;
}
.time-part .digit-wrapper {
  animation-timing-functioncubic-bezier(1010);
}
.time-part.minutes.tens .digit-wrapper {
  animation-name: minutes-tens;
  animation-duration3600s;
  animation-iteration-count1;
}
.time-part.minutes.ones .digit-wrapper {
  animation-name: minutes-ones;
  animation-duration600s;
  animation-iteration-count6;
}
.time-part.seconds.tens .digit-wrapper {
  animation-name: seconds-tens;
  animation-duration60s;
  animation-iteration-count60;
}
.time-part.seconds.ones .digit-wrapper {
  animation-name: seconds-ones;
  animation-duration10s;
  animation-iteration-count360;
}
.time-part.hundredths.tens .digit-wrapper {
  animation-name: hundredths-tens;
  animation-duration1s;
  animation-iteration-count3600;
}
.time-part.hundredths.ones .digit-wrapper {
  animation-name: hundredths-ones;
  animation-duration0.1s;
  animation-iteration-count36000;
}

@keyframes minutes-tens {
  0% {
    transformtranslateY(-180px);
  }
  16.66667% {
    transformtranslateY(-360px);
  }
  33.33333% {
    transformtranslateY(-540px);
  }
  50% {
    transformtranslateY(-720px);
  }
  66.66667% {
    transformtranslateY(-900px);
  }
  83.33333% {
    transformtranslateY(-1080px);
  }
}
@keyframes minutes-ones {
  0% {
    transformtranslateY(-180px);
  }
  10% {
    transformtranslateY(-360px);
  }
  20% {
    transformtranslateY(-540px);
  }
  30% {
    transformtranslateY(-720px);
  }
  40% {
    transformtranslateY(-900px);
  }
  50% {
    transformtranslateY(-1080px);
  }
  60% {
    transformtranslateY(-1260px);
  }
  70% {
    transformtranslateY(-1440px);
  }
  80% {
    transformtranslateY(-1620px);
  }
  90% {
    transformtranslateY(-1800px);
  }
}
@keyframes seconds-tens {
  0% {
    transformtranslateY(-180px);
  }
  16.66667% {
    transformtranslateY(-360px);
  }
  33.33333% {
    transformtranslateY(-540px);
  }
  50% {
    transformtranslateY(-720px);
  }
  66.66667% {
    transformtranslateY(-900px);
  }
  83.33333% {
    transformtranslateY(-1080px);
  }
}
@keyframes seconds-ones {
  0% {
    transformtranslateY(-180px);
  }
  10% {
    transformtranslateY(-360px);
  }
  20% {
    transformtranslateY(-540px);
  }
  30% {
    transformtranslateY(-720px);
  }
  40% {
    transformtranslateY(-900px);
  }
  50% {
    transformtranslateY(-1080px);
  }
  60% {
    transformtranslateY(-1260px);
  }
  70% {
    transformtranslateY(-1440px);
  }
  80% {
    transformtranslateY(-1620px);
  }
  90% {
    transformtranslateY(-1800px);
  }
}
@keyframes hundredths-tens {
  0% {
    transformtranslateY(-180px);
  }
  10% {
    transformtranslateY(-360px);
  }
  20% {
    transformtranslateY(-540px);
  }
  30% {
    transformtranslateY(-720px);
  }
  40% {
    transformtranslateY(-900px);
  }
  50% {
    transformtranslateY(-1080px);
  }
  60% {
    transformtranslateY(-1260px);
  }
  70% {
    transformtranslateY(-1440px);
  }
  80% {
    transformtranslateY(-1620px);
  }
  90% {
    transformtranslateY(-1800px);
  }
}
@keyframes hundredths-ones {
  0% {
    transformtranslateY(-180px);
  }
  10% {
    transformtranslateY(-360px);
  }
  20% {
    transformtranslateY(-540px);
  }
  30% {
    transformtranslateY(-720px);
  }
  40% {
    transformtranslateY(-900px);
  }
  50% {
    transformtranslateY(-1080px);
  }
  60% {
    transformtranslateY(-1260px);
  }
  70% {
    transformtranslateY(-1440px);
  }
  80% {
    transformtranslateY(-1620px);
  }
  90% {
    transformtranslateY(-1800px);
  }
}
body {
  background#F1614B;
  margin0;
  font-family"Aldrich";
}

.wrapper {
  margin100px auto;
  width1000px;
  position: relative;
}
.wrapper:before.wrapper:after {
  content"";
  display: block;
  position: absolute;
  width100%;
  left0;
  height20px;
  z-index10;
}
.wrapper:before {
  top0px;
  background-imageurl('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
  background-size100%;
  background-image-webkit-gradient(linear, 50% 0%50% 100%color-stop(0%#f1614b), color-stop(100%rgba(24197750)));
  background-image-moz-linear-gradient(top, #f1614b 0%rgba(24197750100%);
  background-image-webkit-linear-gradient(top, #f1614b 0%rgba(24197750100%);
  background-imagelinear-gradient(to bottom, #f1614b 0%rgba(24197750100%);
}
.wrapper:after {
  bottom0px;
  background-imageurl('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmMTYxNGIiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
  background-size100%;
  background-image-webkit-gradient(linear, 50% 0%50% 100%color-stop(0%rgba(24197750)), color-stop(100%#f1614b));
  background-image-moz-linear-gradient(top, rgba(241977500%#f1614b 100%);
  background-image-webkit-linear-gradient(top, rgba(241977500%#f1614b 100%);
  background-imagelinear-gradient(to bottom, rgba(241977500%#f1614b 100%);
}

以上是“CSS3中如何实现倒计时效果”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI