本文实例讲述了JS+CSS3实现的简易钟表效果。分享给大家供大家参考,具体如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>www.jb51.net js+css3简易钟表</title> <style type="text/css"> *{ margin: 0; padding: 0; } #wrap{ width: 300px; height: 300px; background-color: aliceblue; margin: 200px auto; position: relative; box-sizing: border-box; } #wrap > div{ position: absolute; top: 50%; left: 50%; } #hour{ width: 6px; height: 60px; background-color: #000000; margin: -60px -3px; transform-origin: 3px 60px; } #min{ width: 4px; height: 80px; background-color: #000000; margin: -80px -2px; transform-origin: 2px 80px; } #sec{ width: 2px; height: 100px; background-color: red; margin: -100px -1px; transform-origin: 1px 100px; } #point{ width: 20px; height: 20px; background-color: burlywood; margin: -10px -10px; border-radius: 50%; } #circle{ width: 300px; height: 300px; position: relative; } #circle li{ list-style: none; width: 2px; height: 6px; background-color: #000000; position: absolute; transform-origin: 1px 150px; left: 149px; top: 0px; } </style> </head> <body> <div id="wrap"> <div id="hour"></div> <div id="min"></div> <div id="sec"></div> <div id="point"></div> <ul id="circle"></ul> </div> </body> <script type="text/javascript"> var hourDom=document.getElementById('hour'); var minDom=document.getElementById('min'); var secDom=document.getElementById('sec'); var cricle=document.getElementById('circle'); //创建表盘,ul宽高为wrap宽高,以wrap中心点为变换基点,动态分配6°的li for (var i=0;i<60;i++) { var li=document.createElement('li'); cricle.appendChild(li); li.style.transform='rotate('+i*6+'deg)'; } //延时函数,确保每一秒更新一次最新时间。并且计算时间准确值。 setInterval(function(){ var date=new Date(); var hour=date.getHours(); var min=date.getMinutes(); var sec=date.getSeconds(); min+=sec/60; hour+=min/60; //当前时间*每个单位时间走的角度=指针指向 hourDom.style.transform='rotate('+hour*30+'deg)'; minDom.style.transform='rotate('+min*6+'deg)'; secDom.style.transform='rotate('+sec*6+'deg)'; },1000) </script> </html>
运行效果:
感兴趣的朋友可使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试一下运行效果。
PS:这里再为大家推荐几款时间及日期相关工具供大家参考使用:
在线日期/天数计算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi
在线日期计算器/相差天数计算器:
http://tools.jb51.net/jisuanqi/datecalc
在线日期天数差计算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq
Unix时间戳(timestamp)转换工具:
http://tools.jb51.net/code/unixtime
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript时间与日期操作技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。