js+css3实现炫酷时钟


Posted in Javascript onAugust 18, 2020

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

html

<body>
    <ul id='box'></ul>
</body>

css

<style>
      *{
        margin: 0;
        padding: 0;
      }
      body{
        background-color: #aaa;
      }
      ul{
        width: 400px;
        height: 400px;
        border: 5px solid skyblue;
        margin: 100px auto 0 auto;
        border-radius: 50%;
         background: radial-gradient(green 50%, yellow 100%);;
        position: relative;

      }
      ul li{
        width: 2px;
        height: 15px;
        list-style: none;
        background-color: #fff;
        position: absolute;
        left: 199px;
        transform-origin: center 200px;
      }

      h1{
        width: 2px;
        height: 180px;
        background-color: orange;
        position: absolute;
        left: 199px;
        top:20px;
        -transition: 1s linear;
        transform-origin: center 180px;
      }
      h2{
        width: 6px;
        height: 160px;
        background-color: #fff;
        position: absolute;
        left: 197px;
        top:40px;
        transform-origin: center 160px;
        border-radius:20%;
      }

      h3{
        width: 8px;
        height: 140px;
        background-color: #fff;
        position: absolute;
        left: 196px;
        top:60px;
        transform-origin: center 140px;
        transform: rotate(0deg);
        border-radius: 20%;
      }
      h4{
        width: 30px;
        height: 30px;
        position: absolute;
        left: 185px;
        top:185px;
        border-radius: 50%;
        background-color: orange;
      }

      span{
        display: inline-block;
        width: 20px;
        height: 20px;
        line-height: 20px;
        text-align: center;
        font-size: 24px;
        position: absolute;
        left: -10px;
        top: 28px;
        color: #fff;
      }

</style>

js

(function(){
      var oUl=document.getElementById('box');
      var timer=null;
      for(var i=0,j=0;i<60;i++,j+=6){
        var oLi=document.createElement('li');
        oLi.style.transform='rotate('+j+'deg)';
        if(i%5==0){
          oLi.style.height='20px';
          var oSpan=document.createElement('span');
          oSpan.style.transform='rotate('+(-j)+'deg)';
          if(i==0){
            oSpan.innerHTML='12';
            oSpan.style.fontSize='30px';
            oSpan.style.left='-17px';
          }else{
            oSpan.innerHTML=parseInt(i/5);
            if(i%15==0){
              oSpan.style.fontSize='36px';
            }
          }
          oLi.appendChild(oSpan);
        }
        if(i==0){
          var oH1=document.createElement('h1');
          var oH2=document.createElement('h2');
          var oH3=document.createElement('h3');
          var oH4=document.createElement('h4');
          oUl.appendChild(oH1);
          oUl.appendChild(oH2);
          oUl.appendChild(oH3);
          oUl.appendChild(oH4);
        }
        oUl.appendChild(oLi);
      }
      var oH=document.getElementsByTagName('h3')[0];
      var oM=document.getElementsByTagName('h2')[0];
      var oS=document.getElementsByTagName('h1')[0];
      timer=setInterval(function(){
         var now = new Date();
         var s=now.getSeconds();
         var m=now.getMinutes()+s/60;
         var h=now.getHours()+m/60;
         oS.style.transform='rotate('+s*6+'deg)';
         oM.style.transform='rotate('+m*6+'deg)';
         oH.style.transform='rotate('+(h%12)*30+'deg)';
      },30);

    })();

作品截图

js+css3实现炫酷时钟

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

Javascript 相关文章推荐
JavaScript中的函数声明和函数表达式区别浅析
Mar 27 Javascript
jQuery Ajax使用实例
Apr 16 Javascript
JavaScript返回上一页的三种方法及区别介绍
Jul 04 Javascript
JavaScript中的ParseInt(&quot;08&quot;)和“09”返回0的原因分析及解决办法
May 19 Javascript
深入理解javascript函数参数与闭包
Dec 12 Javascript
BootStrop前端框架入门教程详解
Dec 25 Javascript
在vue-cli中组件通信的方法
Dec 16 Javascript
Vue.js中关于侦听器(watch)的高级用法示例
May 02 Javascript
ES7之Async/await的使用详解
Mar 28 Javascript
vue服务端渲染操作简单入门实例分析
Aug 28 Javascript
vscode 调试 node.js的方法步骤
Sep 15 Javascript
详解微信小程序动画Animation执行过程
Sep 23 Javascript
纯js+css实现在线时钟
Aug 18 #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
You might like
php ZipArchive压缩函数详解实例
2013/11/06 PHP
关于PHP文件的自动运行方法分析
2016/05/13 PHP
ThinkPHP框架下微信支付功能总结踩坑笔记
2019/04/10 PHP
JavaScript中使用构造函数实现继承的代码
2010/08/12 Javascript
JavaScript中对象property的读取和写入方法介绍
2014/12/30 Javascript
jQuery获得子元素个数的方法
2015/04/14 Javascript
javascript创建函数的20种方式汇总
2015/06/23 Javascript
动态加载js、css的简单实现代码
2016/05/26 Javascript
Angular的MVC和作用域
2016/12/26 Javascript
bootstrap table插件的分页与checkbox使用详解
2017/07/23 Javascript
webpack4之SplitChunksPlugin使用指南
2018/06/12 Javascript
Bootstrap Table列宽拖动的方法
2018/08/15 Javascript
Vue.directive使用注意(小结)
2018/08/31 Javascript
js canvas画布实现高斯模糊效果
2018/11/27 Javascript
jQuery基于随机数解决中午吃什么去哪吃问题示例
2018/12/29 jQuery
angular 服务随记小结
2019/05/06 Javascript
js回溯法计算最佳旅行线路代码实例
2019/09/11 Javascript
使用p5.js实现动态GIF图片临摹重现
2019/10/23 Javascript
微信小程序图片右边加两行文字的代码
2020/04/23 Javascript
Vue3为什么这么快
2020/09/23 Javascript
[01:55]TI9显影之尘系列 - Evil Geniuses
2019/08/22 DOTA
Django查找网站项目根目录和对正则表达式的支持
2015/07/15 Python
Python爬虫抓取手机APP的传输数据
2016/01/22 Python
python实现PID算法及测试的例子
2019/08/08 Python
Python GUI之tkinter窗口视窗教程大集合(推荐)
2020/10/20 Python
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
2012/06/04 HTML / CSS
硅酸盐工业控制专业应届生求职信
2013/11/02 职场文书
大学军训感言300字
2014/03/09 职场文书
毕业生求职自荐书范文
2014/03/27 职场文书
负责人任命书范本
2014/06/04 职场文书
优秀中职教师事迹材料
2014/08/26 职场文书
保密工作承诺书
2014/08/29 职场文书
副总经理岗位职责范本
2014/09/30 职场文书
民事上诉状范文
2015/05/22 职场文书
奔腾年代观后感
2015/06/09 职场文书
MySQL数据库10秒内插入百万条数据的实现
2021/11/01 MySQL