个人收藏的网页特效应用(电脑新建一个文本文档复制粘贴改后缀名为.html就能用)

1、樱花

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
</head>
 
<body>
</body>
 
<script>
            var stop, staticx;
			//#region 
			var img = new Image();
			img.src = "";
 //#endregion
			function Sakura(x, y, s, r, fn) {
				this.x = x;
				this.y = y;
				this.s = s;
				this.r = r;
				this.fn = fn;
			}
 
			Sakura.prototype.draw = function(cxt) {
				cxt.save();
				var xc = 40 * this.s / 4;
				cxt.translate(this.x, this.y);
				cxt.rotate(this.r);
				cxt.drawImage(img, 0, 0, 40 * this.s, 40 * this.s)
				cxt.restore();
			}
 
			Sakura.prototype.update = function() {
				this.x = this.fn.x(this.x, this.y);
				this.y = this.fn.y(this.y, this.y);
				this.r = this.fn.r(this.r);
				if(this.x > window.innerWidth ||
					this.x < 0 ||
					this.y > window.innerHeight ||
					this.y < 0
				) {
					this.r = getRandom('fnr');
					if(Math.random() > 0.4) {
						this.x = getRandom('x');
						this.y = 0;
						this.s = getRandom('s');
						this.r = getRandom('r');
					} else {
						this.x = window.innerWidth;
						this.y = getRandom('y');
						this.s = getRandom('s');
						this.r = getRandom('r');
					}
				}
			}
 
			SakuraList = function() {
				this.list = [];
			}
			SakuraList.prototype.push = function(sakura) {
				this.list.push(sakura);
			}
			SakuraList.prototype.update = function() {
				for(var i = 0, len = this.list.length; i < len; i++) {
					this.list[i].update();
				}
			}
			SakuraList.prototype.draw = function(cxt) {
				for(var i = 0, len = this.list.length; i < len; i++) {
					this.list[i].draw(cxt);
				}
			}
			SakuraList.prototype.get = function(i) {
				return this.list[i];
			}
			SakuraList.prototype.size = function() {
				return this.list.length;
			}
 
			function getRandom(option) {
				var ret, random;
				switch(option) {
					case 'x':
						ret = Math.random() * window.innerWidth;
						break;
					case 'y':
						ret = Math.random() * window.innerHeight;
						break;
					case 's':
						ret = Math.random();
						break;
					case 'r':
						ret = Math.random() * 6;
						break;
					case 'fnx':
						random = -0.5 + Math.random() * 1;
						ret = function(x, y) {
							return x + 0.5 * random - 1.7;
						};
						break;
					case 'fny':
						random = 1.5 + Math.random() * 0.7
						ret = function(x, y) {
							return y + random;
						};
						break;
					case 'fnr':
						random = Math.random() * 0.03;
						ret = function(r) {
							return r + random;
						};
						break;
				}
				return ret;
			}
 
			function startSakura() {
 
				requestAnimationFrame = window.requestAnimationFrame ||
					window.mozRequestAnimationFrame ||
					window.webkitRequestAnimationFrame ||
					window.msRequestAnimationFrame ||
					window.oRequestAnimationFrame;
				var canvas = document.createElement('canvas'),
					cxt;
				staticx = true;
				canvas.height = window.innerHeight;
				canvas.width = window.innerWidth;
				canvas.setAttribute('style', 'position: fixed;left: 0;top: 0;pointer-events: none;');
				canvas.setAttribute('id', 'canvas_sakura');
				document.getElementsByTagName('body')[0].appendChild(canvas);
				cxt = canvas.getContext('2d');
				var sakuraList = new SakuraList();
				for(var i = 0; i < 50; i++) {
					var sakura, randomX, randomY, randomS, randomR, randomFnx, randomFny;
					randomX = getRandom('x');
					randomY = getRandom('y');
					randomR = getRandom('r');
					randomS = getRandom('s');
					randomFnx = getRandom('fnx');
					randomFny = getRandom('fny');
					randomFnR = getRandom('fnr');
					sakura = new Sakura(randomX, randomY, randomS, randomR, {
						x: randomFnx,
						y: randomFny,
						r: randomFnR
					});
					sakura.draw(cxt);
					sakuraList.push(sakura);
				}
				stop = requestAnimationFrame(function() {
					cxt.clearRect(0, 0, canvas.width, canvas.height);
					sakuraList.update();
					sakuraList.draw(cxt);
					stop = requestAnimationFrame(arguments.callee);
				})
			}
 
			window.onresize = function() {
				var canvasSnow = document.getElementById('canvas_snow');
				canvasSnow.width = window.innerWidth;
				canvasSnow.height = window.innerHeight;
			}
 
			img.onload = function() {
				startSakura();
			}
 
			function stopp() {
				if(staticx) {
					var child = document.getElementById("canvas_sakura");
					child.parentNode.removeChild(child);
					window.cancelAnimationFrame(stop);
					staticx = false;
				} else {
					startSakura();
				}
			}
</script>
</html>

2、玫瑰花

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>玫瑰花</title>
</head>

<body>
    <canvas id='c'></canvas>
    <script>
        var b = document.body;
        var c = document.getElementsByTagName('canvas')[0];
        var a = c.getContext('2d');
        document.body.clientWidth;

        with (m = Math) C = cos, S = sin, P = pow,
            R = random; c.width = c.height = f = 600; h = -250; function p(a, b, c) {
                if (c > 60) return [S(a * 7) * (13 + 5 / (.2 + P(b * 4, 4))) - S(b) * 50,
                b * f + 50, 625 + C(a * 7) * (13 + 5 / (.2 + P(b * 4, 4))) + b * 400, a * 1 - b / 2, a]; A = a * 2 - 1; B = b * 2 - 1;
                if (A * A + B * B < 1) {
                    if (c > 37) {
                        n = (j = c & 1) ? 6 : 4; o = .5 / (a + .01) + C(b * 125) * 3 - a * 300; w = b * h; return [o * C(n) + w * S(n) + j * 610 - 390,
                        o * S(n) - w * C(n) + 550 - j * 350, 1180 + C(B + A) * 99 - j * 300, .4 - a * .1 + P(1 - B * B, -h * 6) * .15 - a * b * .4 + C(a + b) / 5 + P(C((o * (a + 1) + (B > 0 ? w : -w)) / 25), 30) * .1 * (1 - B * B), o / 1e3 + .7 - o * w * 3e-6]
                    } if (c > 32) {
                        c = c * 1.16 - .15;
                        o = a * 45 - 20; w = b * b * h; z = o * S(c) + w * C(c) + 620; return [o * C(c) - w * S(c), 28 + C(B * .5) * 99 - b * b * b * 60 - z / 2 - h,
                            z, (b * b * .3 + P((1 - (A * A)), 7) * .15 + .3) * b, b * .7]
                    } o = A * (2 - b) * (80 - c * 2); w = 99 - C(A) * 120 - C(b) * (-h - c * 4.9) + C(P(1 - b, 7)) * 50 + c * 2; z = o * S(c) + w * C(c) + 700;
                    return [o * C(c) - w * S(c), B * 99 - C(P(b, 7)) * 50 - c / 3 - z / 1.35 + 450, z, (1 - b / 1.2) * .9 + a * .1, P((1 - b), 20) / 4 + .05]
                }
            }
        setInterval('for(i=0;i<1e4;i++)if(s=p(R(),R(),i%46/.74)){z=s[2];x=~~(s[0]*f/z-h);y=~~(s[1]*f/z-h);if(!m[q=y*f+x]|m[q]>z)m[q]=z,a.fillStyle="rgb("+~(s[3]*h)+","+~(s[4]*h)+","+~(s[3]*s[3]*-80)+")",a.fillRect(x,y,1,1)}', 0)
    </script>
</body>

</html>

3、记账本

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>记账本</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            list-style: none;
            box-sizing: border-box;
        }

        html {
            font-size: 62.5%;
        }

        body {
            background-color: #f1f1f1;
        }

        .container {
            width: 400px;
            padding: 50px;
            margin: 0 auto;
            position: relative;
        }

        h1 {
            text-align: center;
        }

        .container>p:nth-of-type(2) {
            line-height: 4rem;
            font-size: 3.2rem;
        }

        section {
            height: 6rem;
            padding: 1rem;
            background-color: #fff;
            margin-top: 2rem;
            box-shadow: 1px 1px 3px lightgray;
        }

        section .item {
            width: 50%;
            height: 100%;
            float: left;
            border-right: 1px solid lightgray;
            display: flex;
            flex-wrap: wrap;
            align-content: center;
        }

        section .zhichu {
            border: 0;
        }

        section .item p {
            width: 100%;
            text-align: center;
            font-size: 1.6rem;
            font-weight: 900;
        }

        h2 {
            margin-top: 1.5rem;
            line-height: 4rem;
            font-size: 1.8rem;
            border-bottom: 1px solid lightgray;
        }

        li {
            height: 3rem;
            background-color: #fff;
            margin: 1rem auto;
            font-size: 1.2rem;
            position: relative;
        }

        li span {
            float: left;
            width: 46%;
            height: 3rem;
            line-height: 3rem;
        }

        li .name {
            margin-left: 2%;
        }

        li .money {
            text-align: right;
        }

        li .del {
            width: 2rem;
            height: 2rem;
            line-height: 2rem;
            text-align: center;
            color: #fff;
            background-color: tomato;
            font-size: 1.2rem;
            position: absolute;
            left: -2rem;
            top: .5rem;
            display: none;
        }

        li:hover .del {
            display: block;
        }

        .show {
            line-height: 3.6rem;
            font-size: 1.6rem;
        }

        input {
            display: block;
            width: 100%;
            height: 3rem;
            line-height: 3rem;
            font-size: 1.2rem;
            text-indent: 2.4rem;
        }

        #add {
            height: 3rem;
            line-height: 3rem;
            font-size: 1.4rem;
            color: #fff;
            background-color: plum;
            text-align: center;
            margin-top: 2rem;
        }

        #add:hover {
            cursor: pointer;
        }

        .alert {
            width: 100%;
            font-size: 1.8rem;
            color: #fff;
            text-align: center;
            position: absolute;
            top: 0;
            left: 0;
            transition: all .5s;
            overflow: hidden;
            line-height: 4rem;
        }

        #error {
            background-color: tomato;
            box-shadow: 0 0 5px tomato;
            height: 0;
        }

        #success {
            background-color: skyblue;
            box-shadow: 0 0 5px skyblue;
            height: 0;
        }
    </style>
</head>

<body>
    <div class="container">
        <h1>记账本</h1>
        <p style="margin-top: 2rem;">您的余额</p>
        <p>¥<span id="yue">0</span></p>
        <section>
            <div class="item shouru">
                <p>收入</p>
                <p style="color: skyblue">¥<span id="shouru">0.00</span></p>
            </div>
            <div class="item zhichu">
                <p>支出</p>
                <p style="color: tomato">¥<span id="zhichu">0.00</span></p>
            </div>
        </section>
        <h2>历史记录</h2>
        <ul>
            <!-- <li>
                <span class="name">投资</span>
                <span class="money">-1000</span>
                <span class="del">x</span>
            </li> -->
        </ul>
        <h2>添加新交易</h2>
        <p class="show">交易名称</p>
        <input id="name" type="text" placeholder="请输入名称">
        <p class="show">金额(支出-负数,收入+整数)</p>
        <input id="money" type="text" placeholder="请输入金额">
        <div id="add">添加新交易</div>

        <p id="error" class="alert">请输入正确的信息!</p>
        <p id="success" class="alert">信息添加成功!</p>
    </div>
    <script>
        //关于本地存储的构造函数
        /*localStorage.record = [
            {
        
            },
            {
        
            },
            {
        
            }
        ]*/
        function Record() {
            if (!localStorage.record) {
                localStorage.record = '[]';
            }
        }

        //获取缓存的记录内容
        Record.prototype.getRecords = function () {
            return JSON.parse(localStorage.record);
        }

        //添加新数据
        Record.prototype.addData = function (data) {
            // 拿到数组   添加数据   更新缓存
            var arr = this.getRecords();
            arr.push(data);
            localStorage.record = JSON.stringify(arr);
        }

        //清除所有数据
        Record.prototype.removeAllData = function () {
            localStorage.clear();
        }

        // 删掉指定数据
        Record.prototype.delData = function (index) {
            var arr = this.getRecords();
            arr.splice(index, 1);
            localStorage.record = JSON.stringify(arr);
        }

        //计算总收入
        Record.prototype.shouru = function () {
            var total = 0;
            var arr = this.getRecords();
            arr.forEach(function (data) {
                if (data.type === "+") {
                    total += data.money / 1;
                }
            })
            return total;
        }


        //计算总支出
        Record.prototype.zhichu = function () {
            var total = 0;
            var arr = this.getRecords();
            arr.forEach(function (data) {
                if (data.type === "-") {
                    total += data.money / 1;
                }
            })
            return total;
        }
    </script>
    <script>

        //1.根据缓存显示历史记录
        //创建record对象
        var record = new Record();
        //2.获取历史记录,并添加对应的li
        if (record.getRecords != []) {
            for (let i = 0; i < record.getRecords().length; i++) {
                addLi(record.getRecords()[i]);
            }
        }
        setMoney();
        var namein = document.querySelector('#name');//姓名框
        var moneyin = document.querySelector('#money');//金额框
        var add = document.querySelector('#add');//添加交易
        //记录每一笔钱
        add.addEventListener('click', function () {
            //1.判断输入框的内容
            if (!isAlert()) {
                errorAlert();
                return;
            }
            //2.创建li,填充li,添加li
            //把我们输进去的数据存储在一个集合里
            var data = {
                name: namein.value,
                type: moneyin.value.slice(0, 1),
                money: moneyin.value.slice(1)
            }
            addLi(data);
            record.addData(data);
            setMoney();
            namein.value = '';
            moneyin.value = '';
            successAlert();
        });
        function addLi(data) {
            var ul = document.querySelector('ul');//获取历史记录
            var str = `<li style="border-right:4px solid ${data.type === "+" ? "skyblue" : "tomato"}">
                <span class="name">${data.name}</span>
                <span class="money" style="color:${data.type === "+" ? "skyblue" : "tomato"}">${data.type + data.money}</span>
                <span class="del">x</span>
            </li>`;
            ul.insertAdjacentHTML('beforeend', str);
            var li = ul.children[ul.children.length - 1];
            li.children[li.children.length - 1].addEventListener('click', function () {
                for (let i = 0; i < record.getRecords().length; i++) {
                    if (li.children[0].innerHTML == record.getRecords()[i].name) {
                        record.delData(i);
                    }
                }
                setMoney();
                ul.removeChild(li);
            })
        }
        //输出框内容不合理就提醒用户
        //加减开头,要么就是纯整数,小数的话小数点在整数后且最多两位
        //如果输入框内容不合理,就弹窗提醒用户
        function isAlert() {
            var reg = /^[\+\-](\d+|\d+\.\d{1,2})$/;
            if (namein.value === "" || reg.test(moneyin.value) === false) {
                return false;
            }
            else {
                return true;
            }
        }
        function setMoney() {
            var shouru = document.querySelector('#shouru');
            var zhichu = document.querySelector('#zhichu');
            var yue = document.querySelector('#yue');
            shouru.innerHTML = record.shouru();
            zhichu.innerHTML = record.zhichu();
            yue.innerHTML = record.shouru() - record.zhichu();
        }
        function huifu() {
            var error = document.querySelector('#error');
            error.style.height = '0';
        }
        function errorAlert() {
            var error = document.querySelector('#error');
            error.style.height = '4rem';
            setTimeout(function () {
                error.style.height = '0';
            }, 800);
        }
        function successAlert() {
            var success = document.querySelector('#success');
            success.style.height = '4rem';
            setTimeout(function () {
                success.style.height = '0';
            }, 800);
        }
    </script>
</body>

</html>

4、柠檬茶

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>薄荷柠檬茶</title>
</head>
<style>
html,
body,
.wrapper {
  height: 100%;
}

body {
  overflow: hidden;
  background: #e2e9ed;
}

.wrapper {
  display: grid;
  align-items: center;
  justify-content: center;
}

.cooltea {
  position: relative;
  width: 300px;
  height: 300px;
  border: 20px solid #fff;
  border-radius: 50%;
}
.cooltea:before {
  position: absolute;
  z-index: -2;
  width: 0;
  height: 0;
  content: '';
  border-top: 150px solid #cfe7f5;
  border-right: 150px solid #e2e9ed;
  border-bottom: 150px solid #cfe7f5;
  border-left: 150px solid #cfe7f5;
  border-radius: 150px;
}
.cooltea:after {
  position: absolute;
  z-index: -1;
  top: 70px;
  right: 70px;
  bottom: 70px;
  left: 70px;
  content: '';
  border-radius: 50%;
  background: #5db8b6;
}
.cooltea .liquid {
  position: absolute;
  z-index: 3;
  top: 20px;
  right: 20px;
  bottom: 20px;
  left: 20px;
  transform: translatex(-15px);
  -webkit-animation: liquid 1.5s ease-in-out infinite;
  animation: liquid 1.5s ease-in-out infinite;
  border-radius: 50%;
  background: rgba(139, 233, 193, 0.6);
}
.cooltea .straw {
  position: absolute;
  z-index: 1;
  bottom: 70px;
  left: 50%;
  width: 20px;
  height: 0;
  transform: translatex(-50%);
  border-top: 300px solid #ff7647;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
}
.cooltea .straw:before {
  position: absolute;
  top: -310px;
  right: 0;
  left: 0;
  height: 20px;
  content: '';
  transform: scale(1.5);
  border-radius: 50%;
  background: #cd4727;
}
.cooltea .straw:after {
  position: absolute;
  top: -10px;
  right: 0;
  left: 0;
  height: 20px;
  content: '';
  border-radius: 50%;
  background: #ff7647;
}
.cooltea .straw-surface {
  position: absolute;
  z-index: 5;
  bottom: 240px;
  left: 50%;
  width: 25px;
  height: 0;
  transform: translatex(-50%);
  border-top: 100px solid #ff7647;
  border-right: 2px solid transparent;
  border-left: 2px solid transparent;
}
.cooltea .straw-surface:after {
  position: absolute;
  top: -10px;
  right: 0;
  left: 0;
  height: 20px;
  content: '';
  border-radius: 50%;
  background: #ff7647;
}
.cooltea .ice-cubes {
  transform-origin: 47% 65%;
  -webkit-animation: ice-cubes 8s ease-in-out infinite;
  animation: ice-cubes 8s ease-in-out infinite;
}
.cooltea .ice-cube {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  background: #fff;
}
.cooltea .ice-cube.ice-cube-1 {
  transform: translate(100px, 70px) rotate(10deg);
  background: #bcdbce;
}
.cooltea .ice-cube.ice-cube-2 {
  position: relative;
  z-index: 2;
  transform: translate(160px, 100px) rotate(30deg);
}
.cooltea .ice-cube.ice-cube-3 {
  transform: translate(40px, 0) rotate(-30deg);
}
.cooltea .leaves {
  transform-origin: 46% -42%;
  -webkit-animation: ice-cubes 12s ease-in-out infinite;
  animation: ice-cubes 12s ease-in-out infinite;
}
.cooltea .leave {
  width: 100px;
  height: 70px;
  border-radius: 100px 0;
  background: #19ab87;
}
.cooltea .leave:before {
  position: absolute;
  width: 1px;
  height: 115px;
  content: '';
  transform: rotate(55deg) translate(10px, -53px);
  background: #3fc295;
}
.cooltea .leave.leave-1 {
  transform: translate(40px, -160px) rotate(-30deg);
}
.cooltea .leave.leave-2 {
  transform: translate(160px, -180px) rotate(30deg);
}
.cooltea .leave.leave-3 {
  position: relative;
  z-index: 4;
  transform: translate(70px, -190px) rotate(80deg);
}
.cooltea .lemon-slice {
  position: absolute;
  z-index: 1;
  width: 125px;
  height: 65px;
  transform: translate(146px, -178px) rotate(45deg);
  -webkit-animation: lemon 3s ease-in-out infinite;
  animation: lemon 3s ease-in-out infinite;
  border: 10px solid #ecf9c0;
  border-bottom: 0;
  border-radius: 100px 100px 0 0;
  background: #cff063;
}
.cooltea .lemon-slice:before,
.cooltea .lemon-slice:after {
  position: absolute;
  width: 30px;
  height: 20px;
  content: '';
  border-radius: 50px 0;
  background: #aad815;
}
.cooltea .lemon-slice:after {
  top: 30px;
  left: 30px;
  transform: rotate(90deg);
}
.cooltea .lemon-slice:before {
  top: 30px;
  right: 30px;
  transform: rotate(-40deg);
}
.cooltea .shadow {
  position: absolute;
  z-index: -10;
  top: 50%;
  width: 400px;
  height: 340px;
  transform: translatey(-50%) rotate(45deg);
  transform-origin: 20% 100%;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.2) -60%,
    rgba(0, 0, 0, 0)
  );
}

@-webkit-keyframes liquid {
  from {
    transform: translatex(-15px);
  }
  50% {
    transform: translatex(15px);
  }
  to {
    transform: translatex(-15px);
  }
}

@keyframes liquid {
  from {
    transform: translatex(-15px);
  }
  50% {
    transform: translatex(15px);
  }
  to {
    transform: translatex(-15px);
  }
}
@-webkit-keyframes ice-cubes {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes ice-cubes {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(360deg);
  }
}
@-webkit-keyframes lemon {
  from {
    transform: translate(146px, -178px) rotate(45deg);
  }
  50% {
    transform: translate(146px, -178px) rotate(60deg);
  }
  to {
    transform: translate(146px, -178px) rotate(45deg);
  }
}
@keyframes lemon {
  from {
    transform: translate(146px, -178px) rotate(45deg);
  }
  50% {
    transform: translate(146px, -178px) rotate(60deg);
  }
  to {
    transform: translate(146px, -178px) rotate(45deg);
  }
}

</style>
<body>
    <div class="wrapper">
        <div class="cooltea">
          <div class="liquid"></div>
          <div class="ice-cubes">
            <div class="ice-cube ice-cube-1"></div>
            <div class="ice-cube ice-cube-2"></div>
            <div class="ice-cube ice-cube-3"></div>
          </div>
          <div class="lemon-slice"></div>
          <div class="leaves">
            <div class="leave leave-1"></div>
            <div class="leave leave-2"></div>
            <div class="leave leave-3"></div>
          </div>
          <div class="straw"></div>
          <div class="straw-surface"></div>
          <div class="shadow"></div>
        </div>
      </div>  
</body>

</html>

5、罗盘时钟

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>时钟</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
    <script>
        $(document).ready(function () {
    var style = document.styleSheets[0];
    var monthLeft=$(".main-content .month").css("left");
    var dayLeft=$(".main-content .day").css("left");
    var weekLeft=$(".main-content .week").css("left");
    var shichenLeft=$(".main-content .shichen").css("left");
    var hourLeft=$(".main-content .hour").css("left");
    var minuteLeft=$(".main-content .minute").css("left");
    var secondLeft=$(".main-content .second").css("left");
    var top=$(".main-content .month").css("top");
    var yearLeft=$(".main-content .year span").width()/2;
    var type=1; //类型切换: 0阿拉伯数字 1简体 2繁体 3英文

    //当前日期时间
    var Time={
        currentTime:{
            year:1970,
            month:1,
            day:1,
            hour:0,
            minute:0,
            second:0,
            week:0,
            shichen:{}
        },
        months:[],
        days:[],
        hours:[],
        minutes:[],
        seconds:[],
        shichens:[],
        weeks:[],
        hours:[],
        minutes:[],
        seconds:[],
        yearUnit:"年",
        monthUnit:"月",
        dayUnit:"日",
        weekUnit:"星期",
        hourUnit:"时",
        minuteUnit:"分",
        secondUnit:"秒"
        
    }
    
    var month=Time.currentTime.month;
    var year=Time.currentTime.year;
    initTime(Time,type);

    


    $(".main-content .year").append("<span class='current'>"+Time.currentTime.year+Time.yearUnit+"</span>");

    var h=$(".year span").height();
    top=-(parseInt(top))-parseInt(h)/2;
    top+="px";


    $(".main-content .month").append("<span class='current'>"+Time.currentTime.month+Time.monthUnit+"</span>");
    $(".main-content .day").append("<span class='current'>"+Time.currentTime.day+Time.dayUnit+"</span>");
    $(".main-content .week").append("<span class='current'>"+Time.currentTime.week+"</span>");
    $(".main-content .shichen").append("<span class='current'>"+Time.currentTime.shichen.str+"</span>");
    $(".main-content .hour").append("<span class='current'>"+Time.currentTime.hour+Time.hourUnit+"</span>");
    $(".main-content .minute").append("<span class='current'>"+Time.currentTime.minute+Time.minuteUnit+"</span>");
    $(".main-content .second").append("<span class='current'>"+Time.currentTime.second+Time.secondUnit+"</span>");



    for (const key in Time.months) {
        if (Time.months.hasOwnProperty(key)) {
            const element = Time.months[key];
            if(element!=Time.currentTime.month){
                $(".main-content .month").append("<span>"+element+Time.monthUnit+"</span>");
            }
            
        }
    }

    for (const key in Time.days) {
        if (Time.days.hasOwnProperty(key)) {
            const element = Time.days[key];
            if(element!=Time.currentTime.day){
                $(".main-content .day").append("<span>"+element+Time.dayUnit+"</span>");
            }
            
        }
    }

    for (const key in Time.weeks) {
        if (Time.weeks.hasOwnProperty(key)) {
            const element = Time.weeks[key];
            if(element!=Time.currentTime.week){
                $(".main-content .week").append("<span>"+element+"</span>");
            }
            
            
        }
    }


    for (const key in Time.shichens) {
        if (Time.shichens.hasOwnProperty(key)) {
            const element = Time.shichens[key];
            if(element!=Time.currentTime.shichen.str){
                $(".main-content .shichen").append("<span>"+element+"</span>");
            }
            
        }
    }



    for (const key in Time.hours) {
        if (Time.hours.hasOwnProperty(key)) {
            const element = Time.hours[key];
            if(element!=Time.currentTime.hour){
                $(".main-content .hour").append("<span>"+element+Time.hourUnit+"</span>");
            }
            
        }
        
    }

    for (const key in Time.minutes) {
        if (Time.minutes.hasOwnProperty(key)) {
            const element = Time.minutes[key];
            if(element!=Time.currentTime.minute){
                $(".main-content .minute").append("<span>"+element+Time.minuteUnit+"</span>");
            }
            
        }
        
    }

    for (const key in Time.seconds) {
        if (Time.seconds.hasOwnProperty(key)) {
            const element = Time.seconds[key];
            if(element!=Time.currentTime.second){
                $(".main-content .second").append("<span>"+element+Time.secondUnit+"</span>");
            }
            
        }
        
    }





    setTimeout(function () {
        $(".month span").each(function(index,element){
            $(element).css("animation","month"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes month"+index+"{0%{transform: rotateZ(0);transform-origin: -"+monthLeft+" "+top+";}100%{transform:rotateZ("+-(360/12)*(index)+"deg);transform-origin: -"+monthLeft+" "+top+";}}",style.rules.length);

        });
    }, 0);


    setTimeout(function () {
        $(".day span").each(function(index,element){
            $(element).css("animation","day"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes day"+index+"{0%{transform: rotateZ(0);transform-origin: -"+dayLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.days.length)*index+"deg);transform-origin: -"+dayLeft+" "+top+";}}",style.rules.length);
        });
    }, 1000);

    setTimeout(function () {
        $(".week span").each(function(index,element){
            $(element).css("animation","week"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes week"+index+"{0%{transform: rotateZ(0);transform-origin: -"+weekLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.weeks.length)*index+"deg);transform-origin: -"+weekLeft+" "+top+";}}",style.rules.length);
        });
    }, 2000);




    setTimeout(function () {
        $(".shichen span").each(function(index,element){
            $(element).css("animation","shichen"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes shichen"+index+"{0%{transform: rotateZ(0);transform-origin: -"+shichenLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.shichens.length)*index+"deg);transform-origin: -"+shichenLeft+" "+top+";}}",style.rules.length);
        });
    }, 3000);


    setTimeout(function () {
        $(".hour span").each(function(index,element){
            $(element).css("animation","hour"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes hour"+index+"{0%{transform: rotateZ(0);transform-origin: -"+hourLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.hours.length)*index+"deg);transform-origin: -"+hourLeft+" "+top+";}}",style.rules.length);
        });
        
    }, 4000);

    setTimeout(function () {
        $(".minute span").each(function(index,element){
            $(element).css("animation","minute"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes minute"+index+"{0%{transform: rotateZ(0);transform-origin: -"+minuteLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.minutes.length)*index+"deg);transform-origin: -"+minuteLeft+" "+top+";}}",style.rules.length);
        });
        
    }, 5000);


    setTimeout(function () {
        $(".second span").each(function(index,element){
            $(element).css("animation","second"+index+" 1s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes second"+index+"{0%{transform: rotateZ(0);transform-origin: -"+secondLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.seconds.length)*index+"deg);transform-origin: -"+secondLeft+" "+top+";}}",style.rules.length);
        });
        
    }, 6000);

    

    
    //旋转
    setTimeout(function () {


        $(".year span").css("animation","yearRun 1s linear infinite");
        style.insertRule("@keyframes yearRun {0%{transform: rotateZ(0);transform-origin: -"+yearLeft+" "+top+";}100%{transform:rotateZ(720deg);transform-origin: -"+yearLeft+" "+top+";}}",style.rules.length);


        $($(".main-content .second span")[0]).removeClass("current");
        $(".second span").each(function(index,element){
            $(element).css("animation","secondRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes secondRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+secondLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+secondLeft+" "+top+";}}",style.rules.length);
            
        });


        $($(".main-content .minute span")[0]).removeClass("current");
        $(".minute span").each(function(index,element){
            $(element).css("animation","minuteRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes minuteRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+minuteLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+minuteLeft+" "+top+";}}",style.rules.length);
            
        });


        $($(".main-content .hour span")[0]).removeClass("current");
        $(".hour span").each(function(index,element){
            $(element).css("animation","hourRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes hourRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+hourLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+hourLeft+" "+top+";}}",style.rules.length);
            
        });

        $($(".main-content .shichen span")[0]).removeClass("current");
        $(".shichen span").each(function(index,element){
            $(element).css("animation","shichenRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes shichenRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+shichenLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+shichenLeft+" "+top+";}}",style.rules.length);
            
        });

        $($(".main-content .week span")[0]).removeClass("current");
        $(".week span").each(function(index,element){
            $(element).css("animation","weekRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes weekRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+weekLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+weekLeft+" "+top+";}}",style.rules.length);
            
        });

        $($(".main-content .day span")[0]).removeClass("current");
        $(".day span").each(function(index,element){
            $(element).css("animation","dayRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes dayRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+dayLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+dayLeft+" "+top+";}}",style.rules.length);
            
        });

        $($(".main-content .month span")[0]).removeClass("current");
        $(".month span").each(function(index,element){
            $(element).css("animation","monthRun"+index+" 1s linear infinite");
            style.insertRule("@keyframes monthRun"+index+" {0%{transform: rotateZ(0);transform-origin: -"+monthLeft+" "+top+";}100%{transform:rotateZ("+((index+1)*720)+"deg);transform-origin: -"+monthLeft+" "+top+";}}",style.rules.length);
            
        });


    }, 7000);
    

    //初始化当前时间
    setTimeout(function () {
        var myDate = new Date();
        Time.currentTime.year=myDate.getFullYear();
        Time.currentTime.month=myDate.getMonth()+1;
        Time.currentTime.day=myDate.getDate();
        Time.currentTime.week=myDate.getDay();
        Time.currentTime.hour=myDate.getHours();
        Time.currentTime.minute=myDate.getMinutes();
        Time.currentTime.second=myDate.getSeconds();
        // Time.currentTime.day=27;
        // Time.currentTime.hour=23;
        // Time.currentTime.minute=59;
        // Time.currentTime.second=57;
        // Time.currentTime.day=31;
        // Time.currentTime.month=12;
        month=Time.currentTime.month;
        year=Time.currentTime.year;
        initTime(Time,type);


        $(".main-content .year").html("");
        $(".main-content .year").append("<span class='current'>"+Time.currentTime.year+Time.yearUnit+"</span>");

        $(".main-content .second").html("");
        $(".main-content .second").append("<span class='current'>"+Time.currentTime.second+Time.secondUnit+"</span>");
        for (const key in Time.seconds) {
            if (Time.seconds.hasOwnProperty(key)) {
                const element = Time.seconds[key];
                if(element!=Time.currentTime.second){
                    $(".main-content .second").append("<span>"+element+Time.secondUnit+"</span>");
                }
                
            }
            
        }


        $(".main-content .minute").html("");
        $(".main-content .minute").append("<span class='current'>"+Time.currentTime.minute+Time.minuteUnit+"</span>");
        for (const key in Time.minutes) {
            if (Time.minutes.hasOwnProperty(key)) {
                const element = Time.minutes[key];
                if(element!=Time.currentTime.minute){
                    $(".main-content .minute").append("<span>"+element+Time.minuteUnit+"</span>");
                }
                
            }
            
        }


        $(".main-content .hour").html("");
        $(".main-content .hour").append("<span class='current'>"+Time.currentTime.hour+Time.hourUnit+"</span>");
        for (const key in Time.hours) {
            if (Time.hours.hasOwnProperty(key)) {
                const element = Time.hours[key];
                if(element!=Time.currentTime.hour){
                    $(".main-content .hour").append("<span>"+element+Time.hourUnit+"</span>");
                }
                
            }
            
        }


        $(".main-content .shichen").html("");
        $(".main-content .shichen").append("<span class='current'>"+Time.currentTime.shichen.str+"</span>");
        for (const key in Time.shichens) {
            if (Time.shichens.hasOwnProperty(key)) {
                const element = Time.shichens[key];
                if(element!=Time.currentTime.shichen.str){
                    $(".main-content .shichen").append("<span>"+element+"</span>");
                }
                
            }
            
        }


        $(".main-content .week").html("");
        $(".main-content .week").append("<span class='current'>"+Time.currentTime.week+"</span>");
        for (const key in Time.weeks) {
            if (Time.weeks.hasOwnProperty(key)) {
                const element = Time.weeks[key];
                if(element!=Time.currentTime.week){
                    $(".main-content .week").append("<span>"+element+"</span>");
                }
                
                
            }
            
        }

        $(".main-content .day").html("");
        $(".main-content .day").append("<span class='current'>"+Time.currentTime.day+Time.dayUnit+"</span>");
        for (const key in Time.days) {
            if (Time.days.hasOwnProperty(key)) {
                const element = Time.days[key];
                if(element!=Time.currentTime.day){
                    $(".main-content .day").append("<span>"+element+Time.dayUnit+"</span>");
                }
                
            }
            
        }


        $(".main-content .month").html("");
        $(".main-content .month").append("<span class='current'>"+Time.currentTime.month+Time.monthUnit+"</span>");
        for (const key in Time.months) {
            if (Time.months.hasOwnProperty(key)) {
                const element = Time.months[key];
                if(element!=Time.currentTime.month){
                    $(".main-content .month").append("<span>"+element+Time.monthUnit+"</span>");
                }
                
            }
            
        }



    }, 8000);

    //转到当前时间
    setTimeout(function () {
        $(".second span").each(function(index,element){
            $(element).css("animation","second"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes second"+index+"{0%{transform: rotateZ(0);transform-origin: -"+secondLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.seconds.length)*index+"deg);transform-origin: -"+secondLeft+" "+top+";}}",style.rules.length);

        });


        $(".minute span").each(function(index,element){
            $(element).css("animation","minute"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes minute"+index+"{0%{transform: rotateZ(0);transform-origin: -"+minuteLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.minutes.length)*index+"deg);transform-origin: -"+minuteLeft+" "+top+";}}",style.rules.length);

        });


        $(".hour span").each(function(index,element){
            $(element).css("animation","hour"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes hour"+index+"{0%{transform: rotateZ(0);transform-origin: -"+hourLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.hours.length)*index+"deg);transform-origin: -"+hourLeft+" "+top+";}}",style.rules.length);

        });


        
        $(".shichen span").each(function(index,element){
            $(element).css("animation","shichen"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes shichen"+index+"{0%{transform: rotateZ(0);transform-origin: -"+shichenLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.shichens.length)*index+"deg);transform-origin: -"+shichenLeft+" "+top+";}}",style.rules.length);

        });


        $(".week span").each(function(index,element){
            $(element).css("animation","week"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes week"+index+"{0%{transform: rotateZ(0);transform-origin: -"+weekLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.weeks.length)*index+"deg);transform-origin: -"+weekLeft+" "+top+";}}",style.rules.length);

        });


        $(".day span").each(function(index,element){
            $(element).css("animation","day"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes day"+index+"{0%{transform: rotateZ(0);transform-origin: -"+dayLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.days.length)*index+"deg);transform-origin: -"+dayLeft+" "+top+";}}",style.rules.length);

        });


        $(".month span").each(function(index,element){
            $(element).css("animation","month"+index+" 0s linear");
            $(element).css("animation-fill-mode","forwards");
            style.insertRule("@keyframes month"+index+"{0%{transform: rotateZ(0);transform-origin: -"+monthLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.months.length)*index+"deg);transform-origin: -"+monthLeft+" "+top+";}}",style.rules.length);

        });

    }, 8000);

    setTimeout(function (){
        setInterval(run,1000)
        // run();
    },8000)


    var seci=1;
    var mini=1;
    var houri=1;
    var shicheni=1;
    var weeki=1;
    var dayi=1;
    var monthi=1;
    function run(){
        var next=$(".second span.current").next();


        if(next.text()==""){
            next=$(".second span").first();
        }
        var secang1=6*(seci-1);
        var secang2=6*seci;
        $(".second").css("animation","secondRun"+seci+" 0.5s ease-in-out");
        $(".second").css("animation-fill-mode","forwards");
        //90%{transform: rotateZ("+(secang1)+"deg);transform-origin: -"+secondLeft+" "+top+";} 
        style.insertRule("@keyframes secondRun"+seci+"{0%{transform: rotateZ("+secang1+"deg);transform-origin: -"+secondLeft+" "+top+";} 50%{transform:rotateZ("+(secang2+1)+"deg);transform-origin: -"+secondLeft+" "+top+";} 100%{transform:rotateZ("+secang2+"deg);transform-origin: -"+secondLeft+" "+top+";}}",style.rules.length);

        $(".second span.current").removeClass("current");
        next.addClass("current");
        seci++;
        if(seci>60){
            seci=1;
        }



        //进分钟
        var secText=$(".second span.current").text();

        if(secText=="0秒"||secText=="零秒"||secText=="0 s"){
            var minang1=6*(mini-1);
            var minang2=6*mini;

            var next=$(".minute span.current").next();

            if(next.text()==""){
                next=$(".minute span").first();
            }

            $(".minute").css("animation","minuteRun"+mini+" 0.5s ease-in-out");
            $(".minute").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes minuteRun"+mini+" {0%{transform: rotateZ("+minang1+"deg);transform-origin: -"+minuteLeft+" "+top+";} 100%{transform:rotateZ("+minang2+"deg);transform-origin: -"+minuteLeft+" "+top+";}}",style.rules.length);
            
            $(".minute span.current").removeClass("current");
            next.addClass("current");
            mini++;
            if(mini>60){
                mini=1;
            }
            
        }


        //进小时
        var minText=$(".minute span.current").text();

        if((secText=="0秒"||secText=="零秒"||secText=="0 s") &&(minText=="0分"||minText=="零分"||minText=="0 m")){

            var hourang1=15*(houri-1);
            var hourang2=15*houri;

            var next=$(".hour span.current").next();

            if(next.text()==""){
                next=$(".hour span").first();
            }
            $(".hour").css("animation","hourRun"+houri+" 0.5s ease-in-out");
            $(".hour").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes hourRun"+houri+" {0%{transform: rotateZ("+hourang1+"deg);transform-origin: -"+hourLeft+" "+top+";} 100%{transform:rotateZ("+hourang2+"deg);transform-origin: -"+hourLeft+" "+top+";}}",style.rules.length);
            
            $(".hour span.current").removeClass("current");
            next.addClass("current");
            houri++;
            if(houri>24){
                houri=1;
            }
            
        }

        //进时辰
        var hourText=$(".hour span.current").text();

        if((secText=="0秒"||secText=="零秒"||secText=="0 s") && (minText=="0分"||minText=="零分"||minText=="0 m")&&isShichen(hourText)){
            var shichenang1=30*(shicheni-1);
            var shichenang2=30*shicheni;

            var next=$(".shichen span.current").next();

            if(next.text()==""){
                next=$(".shichen span").first();
            }
            $(".shichen").css("animation","shichenRun"+shicheni+" 0.5s ease-in-out");
            $(".shichen").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes shichenRun"+shicheni+" {0%{transform: rotateZ("+shichenang1+"deg);transform-origin: -"+shichenLeft+" "+top+";} 100%{transform:rotateZ("+shichenang2+"deg);transform-origin: -"+shichenLeft+" "+top+";}}",style.rules.length);
            
            $(".shichen span.current").removeClass("current");
            next.addClass("current");
            shicheni++;
            if(shicheni>30){
                shicheni=1;
            }
            
        }


        //进星期和日
        if((secText=="0秒"||secText=="零秒"||secText=="0 s") && (minText=="0分"||minText=="零分"||minText=="0 m")&&(hourText=="0时"||hourText=="零时"||hourText=="0 h")){
            var weekang1=(360/7)*(weeki-1);
            var weekang2=(360/7)*weeki;
            var dayang1=(360/Time.days.length)*(dayi-1);
            var dayang2=(360/Time.days.length)*dayi;

            console.log(dayang1);
            var nextweek=$(".week span.current").next();
            var nextday=$(".day span.current").next();

            if(nextweek.text()==""){
                nextweek=$(".week span").first();
            }
            if(nextday.text()==""){
                nextday=$(".day span").first();
            }

            $(".week").css("animation","weekRun"+weeki+" 0.5s ease-in-out");
            $(".week").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes weekRun"+weeki+" {0%{transform: rotateZ("+weekang1+"deg);transform-origin: -"+weekLeft+" "+top+";} 100%{transform:rotateZ("+weekang2+"deg);transform-origin: -"+weekLeft+" "+top+";}}",style.rules.length);
            
            $(".day").css("animation","dayRun"+dayi+" 0.5s ease-in-out");
            $(".day").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes dayRun"+dayi+" {0%{transform: rotateZ("+dayang1+"deg);transform-origin: -"+dayLeft+" "+top+";} 100%{transform:rotateZ("+dayang2+"deg);transform-origin: -"+dayLeft+" "+top+";}}",style.rules.length);



            $(".week span.current").removeClass("current");
            nextweek.addClass("current");
            weeki++;
            if(weeki>7){
                weeki=1;
            }

            $(".day span.current").removeClass("current");
            nextday.addClass("current");
            dayi++;
            if(dayi>Time.days.length){
                dayi=1;
            }
            
        }


        //进月
        var dayText=$(".day span.current").text();
        if((dayText=="1 day"||dayText==numToSimp(1)+"日"||dayText==numToTrad(1)+"日"||dayText=="1日")&&(secText=="0秒"||secText=="零秒"||secText=="0 s") && (minText=="0分"||minText=="零分"||minText=="0 m")&&(hourText=="0时"||hourText=="零时"||hourText=="0 h")){

            var monthang1=30*(monthi-1);
            var monthang2=30*monthi;
            

            var next=$(".month span.current").next();

            if(next.text()==""){
                next=$(".month span").first();
            }
            $(".month").css("animation","monthRun"+monthi+" 0.5s ease-in-out");
            $(".month").css("animation-fill-mode","forwards");
            style.insertRule("@keyframes monthRun"+monthi+" {0%{transform: rotateZ("+monthang1+"deg);transform-origin: -"+monthLeft+" "+top+";} 100%{transform:rotateZ("+monthang2+"deg);transform-origin: -"+monthLeft+" "+top+";}}",style.rules.length);
            

            month++;
            if(month>12)
            {
                month=1;
            }
            //更新日
            $(".day").html("");
            Time.days=updateDays(type,year,month,1);
            Time.currentTime.day=getFirstDay(type);
            $(".main-content .day").append("<span class='current'>"+Time.currentTime.day+Time.dayUnit+"</span>");
            for (const key in Time.days) {
                if (Time.days.hasOwnProperty(key)) {
                    const element = Time.days[key];
                    if(element!=Time.currentTime.day){
                        $(".main-content .day").append("<span>"+element+Time.dayUnit+"</span>");
                    }
                    
                }
                
            }
            $(".day span").each(function(index,element){
                $(element).css("animation","day"+index+" 0.5s linear");
                $(element).css("animation-fill-mode","forwards");
                style.insertRule("@keyframes day"+index+"{0%{transform: rotateZ(0);transform-origin: -"+dayLeft+" "+top+";}100%{transform:rotateZ("+-(360/Time.days.length)*(index+1)+"deg);transform-origin: -"+dayLeft+" "+top+";}}",style.rules.length);
            });





            $(".month span.current").removeClass("current");
            next.addClass("current");
            monthi++;
            if(monthi>12){
                monthi=1;
            }
            
        }



        //进年

        if(month==1&&(dayText=="1 day"||dayText==numToSimp(1)+"日"||dayText==numToTrad(1)+"日"||dayText=="1日")&&(secText=="0秒"||secText=="零秒"||secText=="0 s") && (minText=="0分"||minText=="零分"||minText=="0 m")&&(hourText=="0时"||hourText=="零时"||hourText=="0 h")){
            year++;
            Time.currentTime.year=getYear(type,year);
            $(".year span").html(getYear(type,year)+Time.yearUnit);
            
        }

    }

});





function initTime(Time,type){
    switch (type) {
        case 0:

        

            Time.months=getMonths(0,Time.currentTime.month);
            Time.days=getdays(0,Time.currentTime.year,Time.currentTime.month,Time.currentTime.day);
            Time.weeks=getWeeks(0,Time.currentTime.week);
            Time.hours=getHours(0,Time.currentTime.hour);
            Time.minutes=getMinutes(0,Time.currentTime.minute);
            Time.seconds=getSeconds(0,Time.currentTime.second);

            Time.currentTime.week=Time.weekUnit+ getWeek(0,Time.currentTime.week);
            Time.currentTime.shichen=getShiChen(0,Time.currentTime.hour);
            Time.shichens=getShiChens(0,Time.currentTime.shichen);


           
            break;
        case 1:

                
            Time.months=getMonths(1,Time.currentTime.month);
            Time.days=getdays(1,Time.currentTime.year,Time.currentTime.month,Time.currentTime.day);
            Time.weeks=getWeeks(1,Time.currentTime.week);
            Time.hours=getHours(1,Time.currentTime.hour);
            Time.minutes=getMinutes(1,Time.currentTime.minute);
            Time.seconds=getSeconds(1,Time.currentTime.second);

            Time.currentTime.month=numToSimp(Time.currentTime.month);
            Time.currentTime.day=numToSimp(Time.currentTime.day);
            Time.currentTime.week=Time.weekUnit+getWeek(1,Time.currentTime.week);
            Time.currentTime.shichen=getShiChen(1,Time.currentTime.hour);
            Time.shichens=getShiChens(1,Time.currentTime.shichen);
            Time.currentTime.hour=numToSimp(Time.currentTime.hour);
            Time.currentTime.minute=numToSimp(Time.currentTime.minute);
            Time.currentTime.second=numToSimp(Time.currentTime.second);
            Time.currentTime.year=getYear(1,Time.currentTime.year);

            break;
        case 2:


            Time.months=getMonths(2,Time.currentTime.month);
            Time.days=getdays(2,Time.currentTime.year,Time.currentTime.month,Time.currentTime.day);
            Time.weeks=getWeeks(2,Time.currentTime.week);
            Time.hours=getHours(2,Time.currentTime.hour);
            Time.minutes=getMinutes(2,Time.currentTime.minute);
            Time.seconds=getSeconds(2,Time.currentTime.second);


            Time.currentTime.month=numToTrad(Time.currentTime.month);
            Time.currentTime.day=numToTrad(Time.currentTime.day);
            Time.currentTime.week=Time.weekUnit+getWeek(2,Time.currentTime.week);
            Time.currentTime.shichen=getShiChen(2,Time.currentTime.hour);
            Time.shichens=getShiChens(2,Time.currentTime.shichen);
            Time.currentTime.hour=numToTrad(Time.currentTime.hour);
            Time.currentTime.minute=numToTrad(Time.currentTime.minute);
            Time.currentTime.second=numToTrad(Time.currentTime.second);
            Time.currentTime.year=getYear(2,Time.currentTime.year);

            break;
        case 3:

        
            Time.months=getMonths(3,Time.currentTime.month);
            Time.days=getdays(0,Time.currentTime.year,Time.currentTime.month,Time.currentTime.day);
            Time.weeks=getWeeks(3,Time.currentTime.week);
            Time.hours=getHours(3,Time.currentTime.hour);
            Time.minutes=getMinutes(3,Time.currentTime.minute);
            Time.seconds=getSeconds(3,Time.currentTime.second);



            Time.currentTime.month=getMonthEng(Time.currentTime.month);
            Time.currentTime.week=getWeek(3,Time.currentTime.week);
            Time.currentTime.shichen=getShiChen(3,Time.currentTime.hour);
            Time.shichens=getShiChens(3,Time.currentTime.shichen);
            // Time.currentTime.hour=numToEng(Time.currentTime.hour);
            // Time.currentTime.minute=numToEng(Time.currentTime.minute);
            // Time.currentTime.second=numToEng(Time.currentTime.second);
            Time.monthUnit="";
            Time.dayUnit=" day"
            Time.weekUnit=""
            Time.hourUnit=" h"
            Time.minuteUnit=" m"
            Time.secondUnit=" s"
            Time.yearUnit=" Year"
            


            break;
    }
}



    </script>
    <script>
        //简体
function numToSimp(n){
    var str = "";
    var units=parseInt(n%10);
    var tens=parseInt(n/10);
    var trans="零一二三四五六七八九十";



    if(tens>1){
        str=trans.charAt(tens);
    }
    if(tens!=0){
        str+="十";
    }
    if(units!=0){
        str += trans.charAt(units);
    }

    if(tens==0&&units==0){
        str=trans[0];
    }
    
    return str;
}

//繁体
function numToTrad(n){
    var str = "";
    var units=parseInt(n%10);
    var tens=parseInt(n/10);
    var trans="零壹贰叁肆伍陆柒捌玖";
    if(tens>1){
        str=trans.charAt(tens);
    }
    if(tens!=0){
        str+="拾";
    }
    if(units!=0){
        str += trans.charAt(units);
    }

    if(tens==0&&units==0){
        str=trans[0];
    }
    
    return str;
}


//英文
function numToEng(n){
    var str = "";
    var units=parseInt(n%10);
    var tens=parseInt(n/10);
    var trans=[
        ["zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine","ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen"],
        ["twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety"],
    ];
    if(n<20)
    {
        str=trans[0][n];
    }else{
        str=trans[1][tens-2];
        if(units!=0){
            str+=trans[0][units];
        }
    }

    if(tens==0&&units==0){
        str=trans[0][0];
    }
    return str;
}



function isLeapYear(year){
    if(year % 4 == 0 && year %100 != 0 ||year % 400 == 0)
    {
        return true;
    }else{
        return false;
    }
}



function getYear(type,year){
    var res=""
    var units=parseInt(year/1%10);
    var tens=parseInt(year/10%10);
    var hund=parseInt(year/100%10);
    var thou=parseInt(year/1000%10);
    switch(type){
        case 0:
        case 3:
            res=year;
            break;
        case 1:
            res=numToSimp(thou)+numToSimp(hund)+numToSimp(tens)+numToSimp(units);
            break;
        case 2:
            res=numToTrad(thou)+numToTrad(hund)+numToTrad(tens)+numToTrad(units);
            break;
    }
    return res;
}






/*
    获取月份
    参数:0 阿拉伯数字 1简体 2繁体 3英文
*/
function getMonths(type,month){
    var months=new Array();
    var monthsEng=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];
    var i=1;
    switch (type) {
        case 0:
            for(i=month;i<=12;i++)
            {
                months.push(i);
            }
            for(i=1;i<month;i++)
            {
                months.push(i);
            }
            
            break;
        case 1:
            for(i=month;i<=12;i++)
            {
                months.push(numToSimp(i));
            }
            for(i=1;i<month;i++)
            {
                months.push(numToSimp(i));
            }
            break;
        case 2:

            for(i=month;i<=12;i++)
            {
                months.push(numToTrad(i));
            }
            for(i=1;i<month;i++)
            {
                months.push(numToTrad(i));
            }
            break;
        case 3:
            for(i=month-1;i<12;i++)
            {
                months.push(monthsEng[i]);
            }
            for(i=0;i<month-1;i++)
            {
                months.push(monthsEng[i]);
            }
            break;
    }
    return months;
}


function getdays(type,year,month,day){
    var days=new Array();
    var j=1;
    var isLeap=isLeapYear(year);
    switch (type) {
        case 0:
        case 3:
            for(j=day;j<=31;j++)
            {
                days.push(j)
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }
            for(j=1;j<day;j++){
                days.push(j)
            }
            break;
        case 1:
            for(j=day;j<=31;j++)
            {
                days.push(numToSimp(j))
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }

            for(j=1;j<day;j++){
                days.push(numToSimp(j))
            }

            break;
        case 2:
            for(j=day;j<=31;j++)
            {
                days.push(numToTrad(j))
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }

            for(j=1;j<day;j++){
                days.push(numToTrad(j))
            }

            break;
    }
    return days;
}






function getShiChen(type,hour){
    var shichen={
        index:0,
        str:""
    };

    switch(type){
        case 0:
            if(hour>=23||hour<1){
                shichen.index=0;
                shichen.str="23:00-1:00";
            }
            else if(hour>=1&&hour<3){
                shichen.index=1;
                shichen.str="1:00-3:00";
            }
            else if(hour>=3&&hour<5){
                shichen.index=2;
                shichen.str="3:00-5:00";
            }
            else if(hour>=5&&hour<7){
                shichen.index=3;
                shichen.str="5:00-7:00";
            }
            else if(hour>=7&&hour<9){
                shichen.index=4;
                shichen.str="7:00-9:00";
            }
            else if(hour>=9&&hour<11){
                shichen.index=5;
                shichen.str="9:00-11:00";
            }
            else if(hour>=11&&hour<13){
                shichen.index=6;
                shichen.str="11:00-13:00";
            }
            else if(hour>=13&&hour<15){
                shichen.index=7;
                shichen.str="13:00-15:00";
            }
            else if(hour>=15&&hour<17){
                shichen.index=8;
                shichen.str="15:00-17:00";
            }
            else if(hour>=17&&hour<19){
                shichen.index=9;
                shichen.str="17:00-19:00";
            }
            else if(hour>=19&&hour<21){
                shichen.index=10;
                shichen.str="19:00-21:00";
            }
            else if(hour>=21&&hour<23){
                shichen.index=11;
                shichen.str="21:00-23:00";
            }
            break;
        case 1:
        case 2:
            if(hour>=23||hour<1){
                shichen.index=0;
                shichen.str="子时"
            }
            else if(hour>=1&&hour<3){
                shichen.index=1;
                shichen.str="丑时";
            }
            else if(hour>=3&&hour<5){
                shichen.index=2;
                shichen.str="寅时";
            }
            else if(hour>=5&&hour<7){
                shichen.index=3;
                shichen.str="卯时";
            }
            else if(hour>=7&&hour<9){
                shichen.index=4;
                shichen.str="辰时";
            }
            else if(hour>=9&&hour<11){
                shichen.index=5;
                shichen.str="巳时";
            }
            else if(hour>=11&&hour<13){
                shichen.index=6;
                shichen.str="午时";
            }
            else if(hour>=13&&hour<15){
                shichen.index=7;
                shichen.str="未时";
            }
            else if(hour>=15&&hour<17){
                shichen.index=8;
                shichen.str="申时";
            }
            else if(hour>=17&&hour<19){
                shichen.index=9;
                shichen.str="酉时";
            }
            else if(hour>=19&&hour<21){
                shichen.index=10;
                shichen.str="戌时";
            }
            else if(hour>=21&&hour<23){
                shichen.index=11;
                shichen.str="亥时";
            }
            break;
        case 3:
            if(hour>=23||hour<1){
                shichen.index=0;
                shichen.str="23pm to 1am"
            }
            else if(hour>=1&&hour<3){
                shichen.index=1;
                shichen.str="1am to 3am"
            }
            else if(hour>=3&&hour<5){
                shichen.index=2;
                shichen.str="3am to 5am"
            }
            else if(hour>=5&&hour<7){
                shichen.index=3;
                shichen.str="5pm to 7am"
            }
            else if(hour>=7&&hour<9){
                shichen.index=4;
                shichen.str="7pm to 9am"
            }
            else if(hour>=9&&hour<11){
                shichen.index=5;
                shichen.str="9pm to 11am"
            }
            else if(hour>=11&&hour<13){
                shichen.index=6;
                shichen.str="11am to 13pm"
            }
            else if(hour>=13&&hour<15){
                shichen.index=7;
                shichen.str="13pm to 15pm"
            }
            else if(hour>=15&&hour<17){
                shichen.index=8;
                shichen.str="15pm to 17pm"
            }
            else if(hour>=17&&hour<19){
                shichen.index=9;
                shichen.str="17pm to 19pm"
            }
            else if(hour>=19&&hour<21){
                shichen.index=10; 
                shichen.str="19pm to 21pm"
            }
            else if(hour>=21&&hour<23){
                shichen.index=11;
                shichen.str="21pm to 23pm"
            }
            break;
    }



    return shichen;
}

function getShiChens(type,shichen){
    var shichens=new Array();
    var i=0;
    var shichen0=["23:00-1:00","1:00-3:00","3:00-5:00","5:00-7:00","7:00-9:00","9:00-11:00","11:00-13:00","13:00-15:00","15:00-17:00","17:00-19:00","19:00-21:00","21:00-23:00"];
    var shichen1=["子时","丑时","寅时","卯时","辰时","巳时","午时","未时","申时","酉时","戌时","亥时"];
    var shichen3=["23pm to 1am","1am to 3am","3am to 5am","5pm to 7am","7pm to 9am","9pm to 11am","11am to 13pm","13pm to 15pm","15pm to 17pm","17pm to 19pm","19pm to 21pm","21pm to 23pm"];
    switch(type){
        case 0:
            for(i=shichen.index;i<12;i++){
                shichens.push(shichen0[i]);
            }
            for(i=0;i<shichen.index;i++){
                shichens.push(shichen0[i]);
            }
            break;
        case 1:
        case 2:
            for(i=shichen.index;i<12;i++){
                shichens.push(shichen1[i]);
            }
            for(i=0;i<shichen.index;i++){
                shichens.push(shichen1[i]);
            }
            break;
        case 3:
            for(i=shichen.index;i<12;i++){
                shichens.push(shichen3[i]);
            }
            for(i=0;i<shichen.index;i++){
                shichens.push(shichen3[i]);
            }
            break;
    }
    return shichens;
}

function getMonthEng(month){
    var monthsEng=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];
    return monthsEng[month-1];
}



function getWeeks(type,week){
    weeks=[];
    weeksEng=["Sun","Mon","Tues","Wed","Thur","Fri","Sat"];
    var i=0;
    switch(type){
        case 0:
        case 1:
        case 2:
            for(i=week;i<7;i++){
                weeks[i]="星期"+numToSimp(i);
                if(i==0){
                    weeks[i]="星期日"
                }
            }
            for(i=0;i<week;i++){
                weeks[i]="星期"+numToSimp(i);
            }
            break;
        case 3:
            for(i=week;i<7;i++)
            {
                weeks.push(weeksEng[i]);
            }
            for(i=0;i<week;i++)
            {
                weeks.push(weeksEng[i]);
            }
            break;
    }
    return weeks;
}

function getWeek(type,week){
    weekEng=["Sun","Mon","Tues","Wed","Thur","Fri","Sat"];
    res="";
    switch(type){
        case 0:
        case 1:
        case 2:
            if(week==0){
                res="日"
            }else{
                res=numToSimp(week);
            }
            break;
        case 3:
            res=weekEng[week];
            break;
    }
    return res;
}

function getHours(type,hour){
    var hours=new Array();
    var i=0;
    switch(type){
        case 0:
        case 3:
            for(i=hour;i<24;i++){
                hours.push(i);
            }
            for(i=0;i<hour;i++){
                hours.push(i);
            }
            break;
        case 1:
            for(i=hour;i<24;i++){
                hours.push(numToSimp(i));
            }
            for(i=0;i<hour;i++){
                hours.push(numToSimp(i));
            }
            break;
        case 2:
            for(i=hour;i<24;i++){
                hours.push(numToTrad(i));
            }
            for(i=0;i<hour;i++){
                hours.push(numToTrad(i));
            }
            break;
        // case 3:
        //     for(i=hour;i<24;i++){
        //         hours.push(numToEng(i));
        //     }
        //     for(i=0;i<hour;i++){
        //         hours.push(numToEng(i));
        //     }
        //     break;
    }
    return hours;
}


function getMinutes(type,minute){
    var minutes=new Array();
    var i=0;
    switch(type){
        case 0:
        case 3:
            for(i=minute;i<60;i++){
                minutes.push(i);
            }
            for(i=0;i<minute;i++){
                minutes.push(i);
            }
            break;
        case 1:
            for(i=minute;i<60;i++){
                minutes.push(numToSimp(i));
            }
            for(i=0;i<minute;i++){
                minutes.push(numToSimp(i));
            }
            break;
        case 2:
            for(i=minute;i<60;i++){
                minutes.push(numToTrad(i));
            }
            for(i=0;i<minute;i++){
                minutes.push(numToTrad(i));
            }
            break;
        // case 3:
        //     for(i=minute;i<60;i++){
        //         minutes.push(numToEng(i));
        //     }
        //     for(i=0;i<minute;i++){
        //         minutes.push(numToEng(i));
        //     }
        //     break;
    }
    return minutes;
}


function getSeconds(type,second){
    var seconds=new Array();
    var i=0;
    switch(type){
        case 0:
        case 3:
            for(i=second;i<60;i++){
                seconds.push(i);
            }
            for(i=0;i<second;i++){
                seconds.push(i);
            }
            break;
        case 1:
            for(i=second;i<60;i++){
                seconds.push(numToSimp(i));
            }
            for(i=0;i<second;i++){
                seconds.push(numToSimp(i));
            }
            break;
        case 2:
            for(i=second;i<60;i++){
                seconds.push(numToTrad(i));
            }
            for(i=0;i<second;i++){
                seconds.push(numToTrad(i));
            }
            break;
        // case 3:
        //     for(i=second;i<60;i++){
        //         seconds.push(numToEng(i));
        //     }
        //     for(i=0;i<second;i++){
        //         seconds.push(numToEng(i));
        //     }
        //     break;
    }
    return seconds;
}

function isShichen(hour){
    if(hour=="one h"||hour=="three h"||hour=="five h"||hour=="seven h"||hour=="nine h"||hour=="eleven h"||hour=="thirteen h"||hour=="fifteen h"||hour=="seventeen h"||hour=="nineteen h"||hour=="twentyone h"||hour=="twentythree h"
    ||hour=="1时"||hour=="3时"||hour=="5时"||hour=="7时"||hour=="9时"||hour=="11时"||hour=="13时"||hour=="15时"||hour=="17时"||hour=="19时"||hour=="21时"||hour=="23时"
    ||hour=="一时"||hour=="三时"||hour=="五时"||hour=="七时"||hour=="九时"||hour=="十一时"||hour=="十三时"||hour=="十五时"||hour=="十七时"||hour=="十九时"||hour=="二十一时"||hour=="二十三时"
    ||hour=="壹时"||hour=="叁时"||hour=="伍时"||hour=="柒时"||hour=="玖时"||hour=="拾壹时"||hour=="拾叁时"||hour=="拾伍时"||hour=="拾柒时"||hour=="拾玖时"||hour=="贰拾壹时"||hour=="贰拾叁时"
    ||hour=="1 h"||hour=="3 h"||hour=="5 h"||hour=="7 h"||hour=="9 h"||hour=="11 h"||hour=="13 h"||hour=="15 h"||hour=="17 h"||hour=="19 h"||hour=="21 h"||hour=="23 h"){
        return true;
    }
    return false;
}


function updateDays(type,year,month,day){
    var days=new Array();
    var j=1;
    var isLeap=isLeapYear(year);
    switch (type) {
        case 0:
        case 3:
            for(j=day;j<=31;j++)
            {
                days.push(j)
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }
            for(j=1;j<day;j++){
                days.push(j)
            }
            break;
        case 1:
            for(j=1;j<=31;j++)
            {
                days.push(numToSimp(j))
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }

            for(j=1;j<day;j++){
                days.push(numToSimp(j))
            }

            break;
        case 2:
            for(j=1;j<=31;j++)
            {
                days.push(numToTrad(j))
                if(month==2&&isLeap&&j==29){
                    break;
                }
                if(month==2&&!isLeap&&j==28){
                    break;
                }
                if((month==2||month==4||month==6||month==9||month==11)&&j==30){
                    break;
                }

            }

            for(j=1;j<day;j++){
                days.push(numToTrad(j))
            }

            break;
    }
    return days;
}



function getFirstDay(type){
    day=1;
    switch (type) {
        case 1:
            day=numToSimp(day);
            break;
        case 2:
            day=numToTrad(day);
            break;
    }
    return day;
}
    </script>
    <style>

        *{
            margin: 0;
            padding: 0;
        }

        body{
            /* background-color: black; */
            /* color: white; */
            background: url("./timg.jpg") no-repeat;
            background-size: 100% 100%;
            background-attachment: fixed;
            color: #F5F4F6;
            font-size: 12px;
            font-weight: bold;
            overflow: hidden;
            width: 1000px;
            height: 900px;
            
            
        }

        .current{
            color: #D1A3F7;
        }


        .main-content{
            position: absolute; 
            top:50%;
            left: 50%;
        }


        .main-content .year{
            position: relative;
            top: -13px;
            left: -38px;
            text-align: center
        }

        .main-content .year span{
            position: absolute;
            width: 80px;
        }



        .main-content .month{
            position: relative;
            top: -13px;
            left: 40px;
        }

        .month span{
            position: absolute;
            width: 60px;
            
        }




        .main-content .day{
            position: relative;
            top: -13px;
            left: 85px;
        }

        .day span{
            position: absolute;
            width: 65px;
            
        }




        .main-content .week{
            position: relative;
            top: -13px;
            left: 145px;
        }
        .week span{
            position: absolute;
            width: 65px;
            
        }


        .main-content .shichen{
            position: relative;
            top: -13px;
            left: 200px;
        }
        .shichen span{
            position: absolute;
            width: 125px;
            
        }


        .main-content .hour{
            position: relative;
            top: -13px;
            left: 240px;
        }
        .hour span{
            position: absolute;
            width: 60px;
            
        }


        .main-content .minute{
            position: relative;
            top: -13px;
            left: 300px;
        }
        .minute span{
            position: absolute;
            width: 60px;
            
        }


        .main-content .second{
            position: relative;
            top: -13px;
            left: 370px;
        }
        .second span{
            position: absolute;
            width: 60px;
            
        }



    </style>
</head>
<body>

    <div class="main-content">
        <div class="year">
            <!-- <span>2019</span> -->
        </div> 
        <div class="month"></div>
        <div class="day"></div>
        <div class="week"></div>
        <div class="shichen"></div>
        <div class="hour"></div>
        <div class="minute"></div>
        <div class="second"></div>
    </div>


</body>
</html>


6、渐变字

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>渐变字</title>
</head>
<style>
    body {
        margin: 0px;
    }

    #container {
        position: absolute;
        margin: auto;
        width: 100vw;
        height: 80pt;
        top: 0;
        bottom: 0;
        filter: url(#threshold) blur(0.6px);
    }

    #text1,
    #text2 {
        position: absolute;
        width: 100%;
        display: inline-block;
        color:red;

        font-family: 'Raleway', sans-serif;
        font-size: 80pt;

        text-align: center;

        user-select: none;
    }
</style>

<body>

    <div id="container">
        <span id="text1"></span>
        <span id="text2"></span>
    </div>

    <svg id="filters">
        <defs>
            <filter id="threshold">
                <feColorMatrix in="SourceGraphic" type="matrix" values="1 0 0 0 0
									0 1 0 0 0
									0 0 1 0 0
									0 0 0 255 -140" />
            </filter>
        </defs>
    </svg>
    <script>
        const elts = {
            text1: document.getElementById("text1"),
            text2: document.getElementById("text2")
        };
        const texts = [
            "欢迎",
            "来到",
            "CSDN"
        ];

        const morphTime = 1;
        const cooldownTime = 0.25;

        let textIndex = texts.length - 1;
        let time = new Date();
        let morph = 0;
        let cooldown = cooldownTime;

        elts.text1.textContent = texts[textIndex % texts.length];
        elts.text2.textContent = texts[(textIndex + 1) % texts.length];

        function doMorph() {
            morph -= cooldown;
            cooldown = 0;

            let fraction = morph / morphTime;

            if (fraction > 1) {
                cooldown = cooldownTime;
                fraction = 1;
            }

            setMorph(fraction);
        }
        function setMorph(fraction) {


            elts.text2.style.filter = `blur(${Math.min(8 / fraction - 8, 100)}px)`;
            elts.text2.style.opacity = `${Math.pow(fraction, 0.4) * 100}%`;

            fraction = 1 - fraction;
            elts.text1.style.filter = `blur(${Math.min(8 / fraction - 8, 100)}px)`;
            elts.text1.style.opacity = `${Math.pow(fraction, 0.4) * 100}%`;

            elts.text1.textContent = texts[textIndex % texts.length];
            elts.text2.textContent = texts[(textIndex + 1) % texts.length];
        }

        function doCooldown() {
            morph = 0;
             
            elts.text2.style.filter = "";
            elts.text2.style.opacity = "100%";

            elts.text1.style.filter = "";
            elts.text1.style.opacity = "0%";
        }

        function animate() {
            requestAnimationFrame(animate);

            let newTime = new Date();
            let shouldIncrementIndex = cooldown > 0;
            let dt = (newTime - time) / 1200;
            time = newTime;

            cooldown -= dt;

            if (cooldown <= 0) {
                if (shouldIncrementIndex) {
                    textIndex++;
                }

                doMorph();
            } else {
                doCooldown();
            }
        }
        animate();
    </script>
</body>

</html>

代码部分来源于网站,如有侵权,请联系删除。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

隔壁老陈56

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值