最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

如何使用css3绘制出圆形动态时钟(详解)

来源:懂视网 责编:小采 时间:2020-11-02 22:08:38
文档

如何使用css3绘制出圆形动态时钟(详解)

如何使用css3绘制出圆形动态时钟(详解):在这个时间就是金钱的时代,人们的时间意识越来越强,不仅仅是平时的日常生活,在上网的同时也是尤为如此,那么在前端开发的时候,学会使用css3制作一个时钟就显得很有必要了。本篇文章给大家带来的内容是关于,有一定的参考价值,有需要的朋友可以参考一下,
推荐度:
导读如何使用css3绘制出圆形动态时钟(详解):在这个时间就是金钱的时代,人们的时间意识越来越强,不仅仅是平时的日常生活,在上网的同时也是尤为如此,那么在前端开发的时候,学会使用css3制作一个时钟就显得很有必要了。本篇文章给大家带来的内容是关于,有一定的参考价值,有需要的朋友可以参考一下,
在这个时间就是金钱的时代,人们的时间意识越来越强,不仅仅是平时的日常生活,在上网的同时也是尤为如此,那么在前端开发的时候,学会使用css3制作一个时钟就显得很有必要了。本篇文章给大家带来的内容是关于,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

使用css3绘制出圆形动态时钟的原理

  1. 众所周知的是div形状是方形的,那么我们首先需要使用border-radius属性将其变换成圆形。

  2. 为了使指针转动起来,我们需要使用 -webkit-transform-origin:center 100px;来设置我们的旋转基点。然后利用 -webkit-transform: rotate(0);让我们的li旋转相应的角度形成相应的刻度。

  3. 设计好刻度之后,需要涉及一个nth-of-type()的选择器,用来规定其属于父元素的第几个子元素。

  4. 在圆形时钟的正中心我们要设一个div icon用于指针的连接点。

  5. 然后我们利用js获取div之后对表盘的刻度进行渲染。

  6. 最后开一个定时器,每隔一秒执行一次函数。

使用css3绘制出圆形动态时钟的代码

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8"/>
 <title>钟表</title>
<style id="css">
 #wrap{width:200px; height:200px; border:2px solid #000; margin:100px auto;border-radius:50%; position:relative;}
 #wrap ul{margin:0; padding:0; height:200px; position:relative; list-style:none;}
 #wrap ul li{width:2px; height:6px; background:#000; position:absolute; left:99px; top: 0;-webkit-transform-origin:center 100px;}
 /*#wrap ul li:nth-of-type(1){-webkit-transform: rotate(0);}
 #wrap ul li:nth-of-type(2){-webkit-transform: rotate(6deg);}
 #wrap ul li:nth-of-type(3){-webkit-transform: rotate(12deg);}
 #wrap ul li:nth-of-type(4){-webkit-transform: rotate(18deg);}
 #wrap ul li:nth-of-type(5){-webkit-transform: rotate(24deg);}
 #wrap ul li:nth-of-type(6){-webkit-transform: rotate(30deg);}
 #wrap ul li:nth-of-type(7){-webkit-transform: rotate(36deg);}
 #wrap ul li:nth-of-type(8){-webkit-transform: rotate(42deg);}*/
 #wrap ul li:nth-of-type(5n+1){ height:12px;}
 #hour{width:6px; height:45px; background:#000; position:absolute; left:97px; top:55px;-webkit-transform-origin:bottom ;}
 #min{width:4px; height:65px; background:#999; position:absolute; left:98px; top:35px;-webkit-transform-origin:bottom ;}
 #sec{width:2px; height:80px; background:red; position:absolute; left:99px; top:20px;-webkit-transform-origin:bottom ;}
 .icon{width:20px; height:20px; background:#000; border-radius:50%; position:absolute; left:90px; top: 90px;}
 </style>
</head>
<body>
 <div id="wrap">
 <ul id="list">
 <!--<li></li>
 <li></li>
 <li></li>
 <li></li>
 <li></li>
 <li></li>
 <li></li>
 <li></li>-->
 </ul>
 <div id="hour"></div>
 <div id="min"></div>
 <div id="sec"></div>
 <div></div>
 </div>
 <script>
 var oList=document.getElementById("list");//获取到刻度
 var oCss=document.getElementById("css");
 var oHour=document.getElementById("hour");//获取时针
 var oMin=document.getElementById("min");//获取分针
 var oSec=document.getElementById("sec");//获取秒针
 var oLi="";
 var sCss="";
 for (var i=0;i<60;i++) { //一个表盘总共是60个刻度
 sCss+="#wrap ul li:nth-of-type("+(i+1)+"){-webkit-transform: rotate("+i*6+"deg);}";
 oLi+="<li></li>";
 };
 oList.innerHTML=oLi;
 oCss.innerHTML+=sCss;//表盘刻度渲染完成
 toTime();
 setInterval(toTime,1000);
 function toTime(){
 var oDate=new Date();//获取当前时间
 var iSec=oDate.getSeconds();//获取当前秒
 var iMin=oDate.getMinutes()+iSec/60;//获取当前分
 var iHour=oDate.getHours()+iMin/60;//获取当前时
 oSec.style.WebkitTransform="rotate("+iSec*6+"deg)";//秒针转动角度1秒6度 (表盘一圈360度一圈60秒所以一秒6度)
 oMin.style.WebkitTransform="rotate("+iMin*6+"deg)";//分钟转动角度1分6度 (表盘一圈360度一圈60分所以一分6度)
 oHour.style.WebkitTransform="rotate("+iHour*30+"deg)";//时针转动角度一小时30度(表盘一圈360度一圈12小时所以一小时30度)
 };
</script>
</body>
</html>

实例效果如图所示

20180312211258103.gif

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

如何使用css3绘制出圆形动态时钟(详解)

如何使用css3绘制出圆形动态时钟(详解):在这个时间就是金钱的时代,人们的时间意识越来越强,不仅仅是平时的日常生活,在上网的同时也是尤为如此,那么在前端开发的时候,学会使用css3制作一个时钟就显得很有必要了。本篇文章给大家带来的内容是关于,有一定的参考价值,有需要的朋友可以参考一下,
推荐度:
标签: 制作 使用 时钟
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top