JS+CSS3实现的简易钟表效果示例
2019-04-13 20:10
846 查看
本文实例讲述了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程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- JS实现的简易拖放效果示例
- Android编程实现简易弹幕效果示例【附demo源码下载】
- iOS版QQ的黏性下拉刷新效果简易实现
- Android实战简易教程<十四>(介绍SwipeMenuListView-简单实现类似QQ的滑动删除效果)
- JAVA Script 学习之通过setTimeout 实现钟表的效果
- Asp.net 2.0 自定义控件开发[实现GridView多行表头固定表体滚动效果][示例代码下载]
- Jquery实现的一种常用高亮效果示例代码
- jquery实现div阴影效果示例代码
- 通过JQuery实现win8一样酷炫的动态磁贴效果(示例代码)
- 基于JS实现html中placeholder属性提示文字效果示例
- Android开发实现绘制淘宝收益图折线效果示例
- jquery实现背景墙聚光灯效果示例分享
- Android实现状态栏白底黑字效果示例代码
- jQuery实现DIV响应鼠标滑过由下向上展开效果示例【测试可用】
- jQuery插件FusionCharts实现的2D面积图效果示例【附demo源码下载】
- JS实现头条新闻的经典轮播图效果示例
- Android编程之播放器MediaPlayer实现均衡器效果示例
- Google首页google Bar的跳动效果简易实现
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- 基于Two.js实现星球环绕动画效果的示例