JS+CSS3实现的简易钟表效果示例

时间:2021-05-26

本文实例讲述了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程序设计有所帮助。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章