罗盘式时钟的实现纯HTML 代码

前言


前言

简单话不多,今天介绍一款看着有点黑科技的感觉,纯HTML实现的动态时间源码!可以放在你建站的首页里,例如很多站长在用wordpress进行二开,让你的网站更漂亮哦。


一、罗盘式时钟代码

<!DOCTYPE html>
   <html lang="zh-hans">
       <head>
           <meta charset="UTF-8">
           <meta name="viewport" content="width=device-width, initial-scale=1.0">
           <meta http-equiv="X-UA-Compatible" content="ie=edge">
           <title>js仿抖罗盘时钟</title>
           <style>
               *{
                   margin:0;
                   padding:0
              }
              html,body{
                   width:100%;
                   height:100%;
                   background-color:#000;
                   overflow:hidden
              }
              #clock{
                   position:relative;
                  width:100%;
                  height:100%;
                  background:#000
              }
              .label{
                   display:inline-block;
                   color:#4d4d4d;
                  text-align:center;
                  padding:0 5px;
                  font-size:19px;
                  transition:left 1s,top 1s;
                  transform-origin:0% 0%
             }
          </style>     
      </head>
      <body>
          <div id="clock"></div>
          <script>
              var monthText=["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"];
              var dayText=["零一号","零二号","零三号","零四号","零五号","零六号","零七号","零八号","零九号","十号","十一号","十二号","十三号","十四号","十五号","十六号","十七号","十八号","十九号","二十号","二十一号","二十二号","二十三号","二十四号","二十五号","二十六号","二十七号","二十八号","二十九号","三十号","三十一号"];
              var weekText=["星期日","星期一","星期二","星期三","星期四","星期五","星期六"];
              var hourText=["零点","零一点","零两点","零三点","零四点","零五点","零六点","零七点","零八点","零九点","零十点","十一点","十二点","十三点","十四点","十五点","十六点","十七点","十八点","十九点","二十点","二十一点","二十二点","二十三点"];
              var minuteText=["零一分","零二分","零三分","零四分","零五分","零六分","零七分","零八分","零九分","零十分","十一分","十二分","十三分","十四分","十五分","十六分","十七分","十八分","十九分","二十分","二十一分","二十二分","二十三分","二十四分","二十五分","二十六分","二十七分","二十八分","二十九分","三十分","三十一分","三十二分","三十三分","三十四分","三十五分","三十六分","三十七分","三十八分","三十九分","四十分","四十一分","四十二分","四十三分","四十四分","四十五分","四十六分","四十七分","四十八分","四十九分","五十分","五十一分","五十二分","五十三分","五十四分","五十五分","五十六分","五十七分","五十八分","五十九分","六十分"];
              var secondsText=["零一秒","零二秒","零三秒","零四秒","零五秒","零六秒","零七秒","零八秒","零九秒","零十秒","十一秒","十二秒","十三秒","十四秒","十五秒","十六秒","十七秒","十八秒","十九秒","二十秒","二十一秒","二十二秒","二十三秒","二十四秒","二十五秒","二十六秒","二十七秒","二十八秒","二十九秒","三十秒","三十一秒","三十二秒","三十三秒","三十四秒","三十五秒","三十六秒","三十七秒","三十八秒","三十九秒","四十秒","四十一秒","四十二秒","四十三秒","四十四秒","四十五秒","四十六秒","四十七秒","四十八秒","四十九秒","五十秒","五十一秒","五十二秒","五十三秒","五十四秒","五十五秒","五十六秒","五十七秒","五十八秒","五十九秒","六十秒"];
              var clock;var monthList=[];
              var dayList=[];
              var weekList=[];
              var hourList=[];
              var minuteList=[];
              var secondsList=[];
              var isCircle=false;
              var textSet=[[monthText,monthList],[dayText,dayList],[weekText,weekList],[hourText,hourList],[minuteText,minuteList],[secondsText,secondsList]];
              window.onload=function(){
                  init();
                  setInterval(function(){
                       runTime();
                       },100);
                      changePosition();
                      setTimeout(function(){
                      changeCircle();
                      },2000);
                  }
              function init(){
                  clock=document.getElementById('clock');
                  for(var i=0;i<textSet.length;i++){
                     for(var j=0;j<textSet[i][0].length;j++){
                          var temp=createLabel(textSet[i][0][j]);
                         clock.appendChild(temp);textSet[i][1].push(temp);
                      }
                  }
              }
              function createLabel(text)
              {
               var div=document.createElement('div');
              div.classList.add('label');
              div.innerText=text;return div;
              }
              function runTime(){
                  var now=new Date();
                  var month=now.getMonth();
                  var day=now.getDate();
                  var week=now.getDay();
                  var hour=now.getHours();
                  var minute=now.getMinutes();
                  var seconds=now.getSeconds();
                  initStyle();
                  var nowValue=[month,day-1,week,hour,minute,seconds];
                 for(var i=0;i<nowValue.length;i++){
                     var num=nowValue[i];
                     textSet[i][1][num].style.color='#fff';
                  }
                  if(isCircle){
                     var widthMid=document.body.clientWidth/2;
                     var heightMid=document.body.clientHeight/2;
                     for(var i=0;i<textSet.length;i++){
                         for(var j=0;j<textSet[i][0].length;j++){
                             var r=(i+1)*35+50*i;
                             var deg=360/textSet[i][1].length*(j-nowValue[i]);
                             var x=r*Math.sin(deg*Math.PI/180)+widthMid;
                             var y=heightMid-r*Math.cos(deg*Math.PI/180);
                             var temp=textSet[i][1][j];
                             temp.style.transform='rotate('+(-90+deg)+'deg)';
                             temp.style.left=x+'px';
                             temp.style.top=y+'px';
                         }
                     }
                 }
             }
             function initStyle(){
                 var label=document.getElementsByClassName('label');
                 for(var i=0;i<label.length;i++){
                     label[i].style.color='#4d4d4d';
                 }
             }
             function changePosition(){
                 for(let i=;i<textSet.length;i++){
                     for(let j=0;j<textSet[i][1].length;j++){
                         let tempX=textSet[i][1][j].offsetLeft+"px";
                         let tempY=textSet[i][1][j].offsetTop+"px";
                         setTimeout(function(){
                             textSet[i][][j].style.position="absolute";
                             textSet[i][1][j].style.left=tempX;textSet[i][1][j].style.top=tempY;
                         },50);
                      }
                  }
             }
             function changeCircle(){
                 isCircle=true;
                 clock.style.transform="rotate(90deg)";
             }
         </script>
     </body>
 </html>

二、程序演示与下载

程序演示:

 

 程序下载:动态罗盘时钟显示源码


  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 罗盘时钟是一种利用HTML、CSS和JavaScript编写的交互时钟,模拟罗盘指针的运动来显示时间。 详细步骤如下: 1. 创建一个HTML文件,并添加基本的结构和布局。可以使用div元素来分段组织页面的不同部分。 2. 在页面中添加一个div元素来显示罗盘时钟的圆盘。可以设置其宽度、高度以及边框样来模拟罗盘的形状。 3. 通过CSS样来设置罗盘时钟的外观。可以设置背景颜色、字体样、对齐方等。 4. 在页面中添加一个div元素作为时钟的指针,并设置其起始位置。可以使用CSS样设置其形状、颜色和大小。 5. 使用JavaScript代码来获取当前的时间。可以使用Date对象中的方法来获取小时、分钟和秒钟的值。 6. 使用JavaScript代码来计算指针的旋转角度。根据当前时间的小时、分钟和秒钟的值来计算指针应该旋转的角度。 7. 使用JavaScript代码来更新指针的位置和旋转角度。通过修改指针的CSS样中的transform属性来实现指针的旋转和位置变化。 8. 使用JavaScript的定时器函数(例如setInterval)来定期更新指针的位置和旋转角度。可以设置定时器的间隔时间来控制指针的动态效果。 9. 运行HTML文件,即可看到罗盘时钟的效果。指针随着时间的推移而旋转,显示出当前的时间。 以上是罗盘时钟代码的详细步骤。你可以根据自己的喜好和需求对样和布局进行进一步的调整和改进。 ### 回答2: 编写罗盘时钟HTML代码可以分为以下几个步骤: 第一步,编写基本HTML结构: ```html <!DOCTYPE html> <html> <head> <title>罗盘时钟</title> <style> #clock { width: 300px; height: 300px; border: 1px solid #000; border-radius: 50%; position: relative; } </style> </head> <body> <div id="clock"></div> </body> </html> ``` 第二步,编写CSS样,包括时钟的刻度和指针样: ```html <style> ... .hour-hand, .minute-hand, .second-hand { width: 2px; background-color: #000; position: absolute; top: 50%; left: 50%; transform-origin: bottom center; } .hour-hand { height: 100px; z-index: 3; } .minute-hand { height: 150px; z-index: 2; } .second-hand { height: 170px; z-index: 1; } .hour-mark, .minute-mark { width: 2px; height: 10px; background-color: #000; position: absolute; top: 50%; left: 50%; transform-origin: bottom center; } .hour-mark { z-index: 3; } .minute-mark { z-index: 2; } </style> ``` 第三步,编写JavaScript代码实现时钟的动态效果: ```html <script> window.onload = function() { var hourHand = document.createElement("div"); hourHand.className = "hour-hand"; var minuteHand = document.createElement("div"); minuteHand.className = "minute-hand"; var secondHand = document.createElement("div"); secondHand.className = "second-hand"; document.getElementById("clock").appendChild(hourHand); document.getElementById("clock").appendChild(minuteHand); document.getElementById("clock").appendChild(secondHand); function rotateElements() { var date = new Date(); var hours = date.getHours(); var minutes = date.getMinutes(); var seconds = date.getSeconds(); hourHand.style.transform = "rotate(" + ((hours * 30) + (minutes * 0.5) - 90) + "deg)"; minuteHand.style.transform = "rotate(" + ((minutes * 6) - 90) + "deg)"; secondHand.style.transform = "rotate(" + ((seconds * 6) - 90) + "deg)"; } setInterval(rotateElements, 1000); } </script> ``` 以上就是实现罗盘时钟的详细步骤。通过以上代码,你可以在HTML页面中创建一个圆形的时钟,将时钟的刻度和指针以定位的方设置在适当的位置,并通过JavaScript不断地更新指针的旋转角度,从而实现动态的时钟效果。 ### 回答3: 罗盘时钟是一种基于HTMLJavaScript的简单时钟设计。以下是使用HTMLJavaScript编写罗盘时钟的详细步骤: 1. 创建一个新的HTML文件,并使用<html>标签作为根标签。 2. 在<head>标签中,添加一个<title>标签来为页面命名。 3. 在<body>标签中,添加一个<div>标签,并设置一个唯一的id属性,例如id="clock"。 4. 使用CSS样来设计时钟的外观。可以为<div>标签添加style属性,或为CSS文件添加相关样。 5. 在JavaScript代码中,使用document.getElementById()方法获取到<div>标签的引用,例如:const clock = document.getElementById('clock')。 6. 使用JavaScript中的Date对象来获取当前时间。例如,可以使用new Date()创建一个新的Date对象,并使用该对象的getHours()、getMinutes()和getSeconds()方法分别获取当前的小时、分钟和秒数。 7. 将获取到的时间格化为指定的格,并将其设置为<div>标签的内容。可以使用innerHTML属性来设置<div>标签的内容,例如:clock.innerHTML = formattedTime。 8. 创建一个JavaScript函数来更新时钟。可以使用setInterval()方法来定时调用该函数,并更新时钟的内容。 9. 在页面加载完成后,调用更新时钟的函数,以确保时钟能够立即显示正确的时间。 10. 最后,在浏览器中打开HTML文件,即可看到罗盘时钟的效果。 以上便是使用HTMLJavaScript编写罗盘时钟的详细步骤。随着HTMLJavaScript的进一步学习和实践,还可以对时钟进行更多的样和功能的定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值