纯js+css实现在线时钟


Posted in Javascript onAugust 18, 2020

本文实例为大家分享了js+css实现在线时钟的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>时钟</title>
 <style type="text/css">
 *{
 padding: 0;
 margin: 0;
 }
 .wrap{
 position: absolute;
 width: 200px;
 height: 200px;
 border: 2px solid;
 background-color: pink;
 border-radius: 50%;
 left: 50%;
 top: 50%;
 transform: translate(-50%,-50%);
 }
 .wrap>ul{
 list-style: none;
 }
 .wrap>ul>li{
 position: absolute;
 left: 99px;
 top: 0;
 width: 2px;
 height: 10px;
 background-color: black;
 transform-origin: center 100px;
 }
 .wrap>ul>li:nth-child(5n+1){
 height: 15px;
 }
 .wrap > .hour{
 position: absolute;
 left: 97px;
 top:70px ;
 width: 6px;
 height: 30px;
 background: black;
 transform-origin: center bottom;
 }
 .wrap > .min{
 position: absolute;
 left: 98px;
 top: 50px;
 width: 4px;
 height: 50px;
 background: gray;
 transform-origin: center bottom;
 }
 .wrap > .sec{
 position: absolute;
 left: 99px;
 top: 30px;
 width: 2px;
 height: 70px;
 background: red;
 transform-origin: center bottom;
 }
 .wrap > .center{
 position: absolute;
 left: 90px;
 top: 90px;
 width: 20px;
 height: 20px;
 border-radius:50% ;
 background: black;
 }
 </style>
 </head>
 <body>
 <div class="wrap">
 <ul></ul>
 <div class="hour"></div>
 <div class="min"></div>
 <div class="sec"></div>
 <div class="center"></div>
 </div>
 </body>
 <script type="text/javascript">
 window.onload =function(){
 var hourNode =document.querySelector(".wrap > .hour");
 var minNode =document.querySelector(".wrap > .min");
 var secNode =document.querySelector(".wrap > .sec");
 var ulNode =document.querySelector(".wrap>ul");
 var styleNode =document.createElement('style');
 var liHtml ='';
 var styleHtml ='';
 for(var i=0;i<60;i++){
 liHtml += "<li></li>";
 styleHtml+=".wrap>ul>li:nth-child("+(i+1)+"){transform: rotate("+(i*6)+"deg);}"
 }
 ulNode.innerHTML =liHtml;
 styleNode.innerHTML =styleHtml;
 document.querySelector('head').appendChild(styleNode);
 
 moveTime();
 setInterval(moveTime,1000);
 
 function moveTime(){
 var date =new Date();
 var sec =date.getSeconds();
 var min =date.getMinutes()+sec/60;
 var hour =date.getHours()+min/60;
 hourNode.style.transform ="rotate("+(hour*30)+"deg)";
 minNode.style.transform ="rotate("+(min*6)+"deg)";
 secNode.style.transform ="rotate("+(sec*6)+"deg)";
 }
 
 }
 </script>
</html>

纯js+css实现在线时钟

实现要点

1、transform-origin的基本点的应用
2、批量处理html和样式的信息
3、指证位置进行了优化(时针与小时和分针位置有关,分针与分和秒针位置有关)。

新增居中方式:

开启绝对定位 left:50%;top :50%;transform:translate(50%,50%);

更多JavaScript时钟特效点击查看:JavaScript时钟特效专题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript日历实现代码
Sep 12 Javascript
jquery自定义类似$.ajax()的方法实现代码
Aug 13 Javascript
Javascript Web Slider 焦点图示例源码
Oct 10 Javascript
解析Javascript中难以理解的11个问题
Dec 09 Javascript
使用BootStrap实现用户登录界面UI
Aug 10 Javascript
Bootstrap Tooltip显示换行和左对齐的解决方案
Oct 11 Javascript
基于vue-cli 打包时抽离项目相关配置文件详解
Mar 07 Javascript
webpack4 css打包压缩问题的解决
May 18 Javascript
JavaScript对象拷贝与赋值操作实例分析
Dec 10 Javascript
jquery中attr、prop、data区别与用法分析
Sep 25 jQuery
vue-quill-editor的使用及个性化定制操作
Aug 04 Javascript
ES11屡试不爽的新特性,你用上了几个
Oct 21 Javascript
three.js 利用uv和ThreeBSP制作一个快递柜功能
Aug 18 #Javascript
js+css实现扇形导航效果
Aug 18 #Javascript
js实现3D旋转效果
Aug 18 #Javascript
Vue elementui字体图标显示问题解决方案
Aug 18 #Javascript
详解三种方式在React中解决绑定this的作用域问题并传参
Aug 18 #Javascript
javascript实现移动端上传图片功能
Aug 18 #Javascript
八种Vue组件间通讯方式合集(推荐)
Aug 18 #Javascript
You might like
Ajax PHP分页演示
2007/01/02 PHP
ECMall支持SSL连接邮件服务器的配置方法详解
2014/05/19 PHP
利用谷歌 Translate API制作自己的翻译脚本
2014/06/04 PHP
PHP提示Deprecated: mysql_connect(): The mysql extension is deprecated的解决方法
2014/08/28 PHP
微信支付扫码支付php版
2016/07/22 PHP
PHP面向对象程序设计__tostring()和__invoke()用法分析
2019/06/12 PHP
如何在PHP中生成随机数
2020/06/04 PHP
JS模板实现方法
2013/04/03 Javascript
javascript去掉前后空格的实例
2013/11/07 Javascript
js获取对象为null的解决方法
2013/11/21 Javascript
实例详解JavaScript获取链接参数的方法
2016/01/01 Javascript
JQUERY的AJAX请求缓存里的数据问题处理
2016/02/23 Javascript
使用JS和canvas实现gif动图的停止和播放代码
2017/09/01 Javascript
微信小程序-getUserInfo回调的实例详解
2017/10/27 Javascript
在Vue中使用axios请求拦截的实现方法
2018/10/25 Javascript
[42:36]DOTA2上海特级锦标赛B组败者赛 VG VS Spirit第二局
2016/02/26 DOTA
[01:46]2018完美盛典章节片——坚守
2018/12/17 DOTA
利用Python绘制MySQL数据图实现数据可视化
2015/03/30 Python
详解C++编程中一元运算符的重载
2016/01/19 Python
python requests 使用快速入门
2017/08/31 Python
详解关于Django中ORM数据库迁移的配置
2018/10/08 Python
Python实现的各种常见分布算法示例
2018/12/13 Python
选择Python写网络爬虫的优势和理由
2019/07/07 Python
python中怎么表示空值
2020/06/19 Python
翻新二手苹果产品的网络领导者:Mac of all Trades
2017/12/19 全球购物
乌克兰网上服装店:Bolf.ua
2018/10/30 全球购物
高一化学教学反思
2014/02/05 职场文书
手机银行营销方案
2014/03/14 职场文书
三方合作协议书范本
2014/04/18 职场文书
公共场所禁烟标语
2014/06/25 职场文书
男性健康日的活动方案
2014/08/18 职场文书
学用政策心得体会
2014/09/10 职场文书
2014年大学生党员评议表自我评价
2014/09/20 职场文书
车辆委托书范本
2014/10/05 职场文书
大二学生自我检讨书
2014/10/23 职场文书
《文化苦旅》读后感:阅读,让人诗意地栖居在大地上
2019/12/24 职场文书