JS实现钟表效果

2017 三月
18

JS实现钟表效果

JS实现钟表效果


通过new Date();获取实时时间然后通过css3的定位和旋转实现钟表效果




css代码:

  1. <style>  
  2.     .clock {  
  3.         positionrelative;  
  4.         width400px;  
  5.         height400px;  
  6.         margin20px auto;  
  7.         border-radius: 50%;  
  8.         backgroundurl(images/clock.png);  
  9.     }  
  10.     .clock div:nth-child(1), .clock div:nth-child(2), .clock div:nth-child(3), .clock div:nth-child(4) {  
  11.         positionabsolute;  
  12.         -webkit-transform-origin: bottom;  
  13.     }  
  14.     .clock div:nth-child(1) {  
  15.         top: 45px;  
  16.         left: 197px;  
  17.         width4px;  
  18.         height160px;  
  19.         border-top-right-radius: 50px;  
  20.         background#343339;  
  21.     }  
  22.     .clock div:nth-child(2) {  
  23.         top: 80px;  
  24.         left: 195px;  
  25.         width6px;  
  26.         height120px;  
  27.         border-top-right-radius: 10px;  
  28.         border-bottom-right-radius: 10px;  
  29.         background#343332;  
  30.     }  
  31.     .clock div:nth-child(3) {  
  32.         top: 100px;  
  33.         left: 195px;  
  34.         width8px;  
  35.         height100px;  
  36.         border-top-right-radius: 10px;  
  37.         border-bottom-right-radius: 10px;  
  38.         background#010001;  
  39.     }  
  40.     .clock div:nth-child(4) {  
  41.         top: 189px;  
  42.         left: 188px;  
  43.         width20px;  
  44.         height20px;  
  45.         border1px solid #fff;  
  46.         border-radius: 50%;  
  47.         background: rgba(237200451);  
  48.     }  
  49.    </style>  
    <style>
        .clock {
            position: relative;
            width: 400px;
            height: 400px;
            margin: 20px auto;
            border-radius: 50%;
            background: url(images/clock.png);
        }
        .clock div:nth-child(1), .clock div:nth-child(2), .clock div:nth-child(3), .clock div:nth-child(4) {
            position: absolute;
            -webkit-transform-origin: bottom;
        }
        .clock div:nth-child(1) {
            top: 45px;
            left: 197px;
            width: 4px;
            height: 160px;
            border-top-right-radius: 50px;
            background: #343339;
        }
        .clock div:nth-child(2) {
            top: 80px;
            left: 195px;
            width: 6px;
            height: 120px;
            border-top-right-radius: 10px;
            border-bottom-right-radius: 10px;
            background: #343332;
        }
        .clock div:nth-child(3) {
            top: 100px;
            left: 195px;
            width: 8px;
            height: 100px;
            border-top-right-radius: 10px;
            border-bottom-right-radius: 10px;
            background: #010001;
        }
        .clock div:nth-child(4) {
            top: 189px;
            left: 188px;
            width: 20px;
            height: 20px;
            border: 1px solid #fff;
            border-radius: 50%;
            background: rgba(237, 200, 45, 1);
        }
    </style>


html代码:

  1. <div class=“clock”>  
  2.         <div id=“sec”></div>  
  3.         <div id=“min”></div>  
  4.         <div id=“hour”></div>  
  5.         <div></div>  
  6.     </div>  
<div class="clock">
        <div id="sec"></div>
        <div id="min"></div>
        <div id="hour"></div>
        <div></div>
    </div>


js代码:

[javascript] view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. <script>  
  2.     var hour = document.getElementById(‘hour’);  
  3.     var min = document.getElementById(‘min’);  
  4.     var sec = document.getElementById(‘sec’);  
  5.     var timer = null;  
  6.     function sport (){  
  7.         var time = new Date();  
  8.         sec.style.webkitTransform = ’rotate(‘ + time.getSeconds() * 6 + ‘deg)’;  
  9.         min.style.webkitTransform = ’rotate(‘ + (time.getMinutes() + time.getSeconds() / 60) * 6 + ‘deg)’;  
  10.         hour.style.WebkitTransform = ’rotate(‘ + (time.getHours() % 12 + time.getMinutes() / 60 + time.getSeconds() / 3600) * 30 + ‘deg)’;  
  11.         console.log(sec.style.WebkitTransform);  
  12.     }sport ();  
  13.     setInterval(sport, 1000);  
  14. </script>  
  <script>
        var hour = document.getElementById('hour');
        var min = document.getElementById('min');
        var sec = document.getElementById('sec');
        var timer = null;
        function sport (){
            var time = new Date();
            sec.style.webkitTransform = 'rotate(' + time.getSeconds() * 6 + 'deg)';
            min.style.webkitTransform = 'rotate(' + (time.getMinutes() + time.getSeconds() / 60) * 6 + 'deg)';
            hour.style.WebkitTransform = 'rotate(' + (time.getHours() % 12 + time.getMinutes() / 60 + time.getSeconds() / 3600) * 30 + 'deg)';
            console.log(sec.style.WebkitTransform);
        }sport ();
        setInterval(sport, 1000);
    </script>








            </div>
            <div class="rssFix">
                <a href="http://blog.csdn.net/qq_35515563/rss/list" class="column" onclick="_gaq.push(['_trackEvent','function', 'onclick', 'blog_articles_RSS'])"><i class="fa fa-rss"></i></a>
            </div>        

            <div id="goTopBtn" class="skin_backTop"><i class="fa fa-chevron-up"></i></div>
    </div>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值