js时钟特效

2021-07-04  本文已影响0人  每天进步一点点的zh

用js实现时钟特效,可以直接复制看效果哟,快来试试吧!



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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>

*{margin:0;
padding:0;}
ul{
    list-style: none;
}
.watch{
    position:absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
    width:400px;
    height: 400px;
    background-color: rgb(171, 172, 173);
    border: 30px solid rgb(117, 110, 110);
    border-radius: 50%;
  
}
/* 这段代码是核心 */
.num{
    position: absolute;
    top:50%;
    left:50%;
    margin-top: -13px;
    /* border:1px solid red; */
    width:48%;
    /* 文字在右边 */
    text-align: right;
    
    /* 旋转轴 */
    transform-origin: left center;
}
.num1{
   
    transform: rotate(-60deg);
}

.num1 span{
    display:inline-block;
    transform:rotate(60deg);
}
.num2{
    transform: rotate(-30deg);
}

.num2 span{
    display:inline-block;
    transform:rotate(30deg);
}

.num3{
    transform: rotate(0deg);
}


.num4{
    transform: rotate(30deg);
}
.num4 span{
    display:inline-block;
    transform:rotate(-30deg);
}

.num5{
    transform: rotate(60deg);
}
.num5 span{
    display:inline-block;
    transform:rotate(-60deg);
}

.num6{
    transform: rotate(90deg);
}
.num6 span{
    display:inline-block;
    transform:rotate(-90deg);
}

.num7{
    transform: rotate(120deg);
}
.num7 span{
    display:inline-block;
    transform:rotate(-120deg);
}
.num8{
    transform: rotate(150deg);
}
.num8 span{
    display:inline-block;
    transform:rotate(-150deg);
}

.num9{
    transform: rotate(180deg);
}
.num9 span{
    display:inline-block;
    transform:rotate(180deg);
}

.num9 span{
    display:inline-block;
    transform:rotate(-180deg);
}

.num10{
    transform: rotate(210deg);
}

.num10 span{
    display:inline-block;
    transform:rotate(-210deg);
}


.num11{
    transform: rotate(240deg);
}

.num11 span{
    display:inline-block;
    transform:rotate(-240deg);
}


.num12{
    transform: rotate(270deg);
}

.num12 span{
    display:inline-block;
    transform:rotate(-270deg);
}


/*尾类元素,就是可以不用在文档中定义,但一定要content */
.pointer::after{
    content:'';
    width:30px;
    height:30px;
    background-color: rgb(66, 71, 66);
    position:absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
    border-radius: 50%;

}
.pointer>div{
    transform-origin: left center;
    /* background-color: rgb(20, 7, 197); */
    position:absolute;
    top:50%;
    left:50%;
    /* transform: translate(-50%,-50%); */
    margin-top: -5px;
    width:40px;
    height:9px;
 
}
.sec_pointer{
    animation: aa 60s linear infinite;
    width:30%;
    /* background-color: rgb(231, 10, 10); */
    transform:rotate(-90deg);
}

.sec_pointer::after{
    /* 她的尾元素和它一起转动 */
    content:'';
    position:absolute;
    top:0;
    width:0;
    height: 0;
    border:10px solid transparent;
    border-width:5px 0px 9px 150px;
    border-left-color:red;
  

}

.hour_pointer{
    animation: aa 3600s linear infinite;
    width:30%;
    /* background-color: rgb(231, 10, 10); */
    transform:rotate(-60deg);
}

.hour_pointer::after{
    /* 她的尾元素和它一起转动 */
    content:'';
    position:absolute;
    top:0;
    width:0;
    height: 0;
    border:10px solid transparent;
    border-width:5px 0px 9px 130px;
    border-left-color:rgb(225, 240, 14);
    mix-blend-mode: screen;

}



.min_pointer{
    animation: aa 42300s linear infinite;
    width:30%;
    /* background-color: rgb(231, 10, 10); */
    transform:rotate(-30deg);
}

.min_pointer::after{
    /* 她的尾元素和它一起转动 */
    content:'';
    position:absolute;
    top:0;
    width:0;
    height: 0;
    border:10px solid transparent;
    border-width:5px 0px 9px 70px;
    border-left-color:rgb(245, 16, 188);
}


@keyframes aa{
    /* 初始位置时就已经变换好了 */
    from{transform:rotate(-90deg)}
     to{transform:rotate(360deg)}

}






    </style>
</head>


<body>
    <div class="watch">
        <ul>
            <li class="num num1"><span>1</span></li>
            <li class="num num2"><span>2</span></li>
            <li class="num num3"><span>3</span></li>
            <li class="num num4"><span>4</span></li>
            <li class="num num5"><span>5</span></li>
            <li class="num num6"><span>6</span></li>
            <li class="num num7"><span>7</span></li>
            <li class="num num8"><span>8</span></li>
            <li class="num num9"><span>9</span></li>
            <li class="num num10"><span>10</span></li>
            <li class="num num11"><span>11</span></li>
            <li class="num num12"><span>12</span></li>
        </ul>
        <div class="pointer">
            <div class="hour_pointer"></div>
            <div class="min_pointer"></div>
            <div class="sec_pointer"></div>
        </div>

    </div>
</body>

</html>
上一篇 下一篇

猜你喜欢

热点阅读