```
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
/* Play with speed and easing of the animation */
/* =========================================== */
.digit {
display: inline-block;
font-size: 200px;
color: rgba(0, 0, 0, 0.25);
height: 180px;
line-height: 1;
}
.time-part-wrapper {
display: inline-block;
margin-right: 50px;
position: relative;
}
.time-part-wrapper:not(:last-child):after {
content: ":";
display: block;
width: 30px;
height: 230px;
position: absolute;
top: 0px;
right: -30px;
color: rgba(0, 0, 0, 0.25);
font-size: 200px;
line-height: 0.9;
}
.time-part {
width: 140px;
text-align: center;
height: 180px;
overflow: hidden;
display: inline-block;
margin-left: -5px;
box-sizing: border-box;
}
.time-part .digit-wrapper {
animation-timing-function: cubic-bezier(1, 0, 1, 0);
}
.time-part.minutes.tens .digit-wrapper {
animation-name: minutes-tens;
animation-duration: 3600s;
animation-iteration-count: 1;
}
.time-part.minutes.ones .digit-wrapper {
animation-name: minutes-ones;
animation-duration: 600s;
animation-iteration-count: 6;
}
.time-part.seconds.tens .digit-wrapper {
animation-name: seconds-tens;
animation-duration: 60s;
animation-iteration-count: 60;
}
.time-part.seconds.ones .digit-wrapper {
animation-name: seconds-ones;
animation-duration: 10s;
animation-iteration-count: 360;
}
.time-part.hundredths.tens .digit-wrapper {
animation-name: hundredths-tens;
animation-duration: 1s;
animation-iteration-count: 3600;
}
.time-part.hundredths.ones .digit-wrapper {
animation-name: hundredths-ones;
animation-duration: 0.1s;
animation-iteration-count: 36000;
}
@keyframes minutes-tens {
0% {
transform: translateY(-180px);
}
16.66667% {
transform: translateY(-360px);
}
33.33333% {
transform: translateY(-540px);
}
50% {
transform: translateY(-720px);
}
66.66667% {
transform: translateY(-900px);
}
83.33333% {
transform: translateY(-1080px);
}
}
@keyframes minutes-ones {
0% {
transform: translateY(-180px);
}
10% {
transform: translateY(-360px);
}
20% {
transform: translateY(-540px);
}
30% {
transform: translateY(-720px);
}
40% {
transform: translateY(-900px);
}
50% {
transform: translateY(-1080px);
}
60% {
transform: translateY(-1260px);
}
70% {
transform: translateY(-1440px);
}
80% {
transform: translateY(-1620px);
}
90% {
transform: translateY(-1800px);
}
}
@keyframes seconds-tens {
0% {
transform: translateY(-180px);
}
16.66667% {
transform: translateY(-360px);
}
33.33333% {
transform: translateY(-540px);
}
50% {
transform: translateY(-720px);
}
66.66667% {
transform: translateY(-900px);
}
83.33333% {
transform: translateY(-1080px);
}
}
@keyframes seconds-ones {
0% {
transform: translateY(-180px);
}
10% {
transform: translateY(-360px);
}
20% {
transform: translateY(-540px);
}
30% {
transform: translateY(-720px);
}
40% {
transform: translateY(-900px);
}
50% {
transform: translateY(-1080px);
}
60% {
transform: translateY(-1260px);
}
70% {
transform: translateY(-1440px);
}
80% {
transform: translateY(-1620px);
}
90% {
transform: translateY(-1800px);
}
}
@keyframes hundredths-tens {
0% {
transform: translateY(-180px);
}
10% {
transform: translateY(-360px);
}
20% {
transform: translateY(-540px);
}
30% {
transform: translateY(-720px);
}
40% {
transform: translateY(-900px);
}
50% {
transform: translateY(-1080px);
}
60% {
transform: translateY(-1260px);
}
70% {
transform: translateY(-1440px);
}
80% {
transform: translateY(-1620px);
}
90% {
transform: translateY(-1800px);
}
}
@keyframes hundredths-ones {
0% {
transform: translateY(-180px);
}
10% {
transform: translateY(-360px);
}
20% {
transform: translateY(-540px);
}
30% {
transform: translateY(-720px);
}
40% {
transform: translateY(-900px);
}
50% {
transform: translateY(-1080px);
}
60% {
transform: translateY(-1260px);
}
70% {
transform: translateY(-1440px);
}
80% {
transform: translateY(-1620px);
}
90% {
transform: translateY(-1800px);
}
}
body {
background: #F1614B;
margin: 0;
font-family: "Aldrich";
}
.wrapper {
margin: 100px auto;
width: 1000px;
position: relative;
}
.wrapper:before,
.wrapper:after {
content: "";
display: block;
position: absolute;
width: 100%;
left: 0;
height: 20px;
z-index: 10;
}
.wrapper:before {
top: 0px;
background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
background-size: 100%;
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #f1614b), color-stop(100%, rgba(241, 97, 75, 0)));
background-image: -moz-linear-gradient(top, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
background-image: -webkit-linear-gradient(top, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
background-image: linear-gradient(to bottom, #f1614b 0%, rgba(241, 97, 75, 0) 100%);
}
.wrapper:after {
bottom: 0px;
background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2YxNjE0YiIgc3RvcC1vcGFjaXR5PSIwLjAiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmMTYxNGIiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=');
background-size: 100%;
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(241, 97, 75, 0)), color-stop(100%, #f1614b));
background-image: -moz-linear-gradient(top, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
background-image: -webkit-linear-gradient(top, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
background-image: linear-gradient(to bottom, rgba(241, 97, 75, 0) 0%, #f1614b 100%);
}
</style>
</head>
<body>
<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>
</body>
</html>
```
- 筆記內容來源
- 你不知道的JavaScript上
- vue
- 環境搭建
- node和npm安裝配置
- 安裝vue-cli并初始化vue項目
- 安裝配置elementUI
- vuex安裝配置
- axios安裝配置
- main.js
- vue基礎入門
- vue-router介紹
- vuex
- vue 原理學習源碼學習
- js正則處理v-bind和語法
- 雙向綁定
- 虛擬dom
- mvvm和render函數
- vue工作項目筆記
- elementUI 表格分頁多選記憶功能
- elementUI表格展開一行
- keepAlive
- vue整合ckeditor5
- this.$router.push 內打開新窗口
- java修改上傳圖片的權限
- 兼容ie11
- 生成二維碼
- base64圖片下載(兼容IE10)
- vue新手引導程序intro.js
- vue插件 devtools
- vue刷新當前頁面
- vue 錨點導航
- axios
- axios與springmvc
- vue-cli 3搭建vue
- git
- git常用命令
- 正則表達式
- 實例demo
- 1
- 新手引導頁
- 純css3從左顯示下劃線動畫導航菜單
- 純css3從中間顯示下劃線動畫導航菜單
- css顯示密碼
- 倒計時時鐘
- 星星評分
- 按鈕懸停效果
- 步驟條
- css動畫按鈕
- input標題獲得焦點上移
- css圖片放大
- css鏡像導航欄
- js
- 通信
- for in 和 for of
- 前端安全問題
- Promise
- 掘金冴羽學習筆記
- 模擬call
- 模擬bind
- 閉包
- 1 作用域
- 2 執行上下文棧
- 3 變量對象
- 4 作用域鏈
- 5 this
- 面向對象
- 基礎知識點
- 渲染機制
- 其他
- 判斷是否為數組
- http
- css
- 基礎知識
- css陰影