存css实现动态时钟背景

这篇具有很好参考价值的文章主要介绍了存css实现动态时钟背景。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

存css实现动态时钟背景,html5/js,css,前端文章来源地址https://www.toymoban.com/news/detail-579251.html

代码实现

<!DOCTYPE html>
<html lang="en">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>Title</title>
  <meta name="referrer" content="no-referrer">
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=Edge">
    <meta name="viewport"
          content="width=device-width,initial-scale=1.0,user-scalable=no,minimum-scale=1,maximum-scale=1">
    <meta HTTP-EQUIV="pragma" content="no-cache">
    <meta HTTP-EQUIV="Cache-Control" content="no-cache, must-revalidate">
    <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no">
    <meta HTTP-EQUIV="expires" content="0">
    <meta name="viewport"
          content="width=device-width,initial-scale=1,minimum-scale=1, maximum-scale=1, user-scalable=no, viewport-fit=cover"/>
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="full-screen" content="yes">
    <meta name="x5-fullscreen" content="true">
    <meta name="apple-mobile-web-app-capable" content="yes"/>
    <link href="https://fonts.googleapis.com/css2?family=Poppins:wght@600;900&display=swap" rel="stylesheet">
</head>
<style>
    html{
      background: #000;
      color: #4f4f4f;
      font-size: 1em;
      overflow:hidden;
      font-weight: bold;
    }
    *{
      margin: 0;
      padding: 0;
    }
    span{
      display: block;
      float: left;
    }
    .on{
      color: #d0d0d0;
    }
    .wrapper{
      width: 200px;
      height: 200px;
      position: absolute;
      left:50%;
      top:50%;
      margin-top: -100px;
      margin-left: -100px;
    }
    .wrapper .timebox{
      position: absolute;
      width: 200px;
      height: 200px;
      left:0;
      top:0;
      border-radius: 100%;
      transition: all 0.5s;
    }
    .timebox span{
      transition: all 0.5s;
      float: left;
    }
    .wrapper  .timebox span{
      position: absolute;
      left:50%;
      top:50%;
      width: 40px;
      height: 18px;
      margin-top: -9px;
      margin-left: -20px;
      text-align: right;
    }
</style>

<body>

  <div id="wrapper">
    <div class="timebox nianBox" id="nianBox"></div>
    <div class="timebox yuebox" id="yueBox"></div>
    <div class="timebox riqiBox" id="riqiBox"></div>
    <div class="timebox hourbox" id="hourbox"></div>
    <div class="timebox minutebox" id="minutebox"></div>
    <div class="timebox secondbox" id="secondbox"></div>
  </div>

<script>

  let wrapper = document.getElementById("wrapper");
  let nianBox = document.getElementById("nianBox");
  let yueBox = document.getElementById("yueBox");
  let riqiBox = document.getElementById("riqiBox");
  let hourbox = document.getElementById("hourbox");
  let minutebox = document.getElementById("minutebox");
  let secondbox = document.getElementById("secondbox");

  /*
  * 找所有的东西标签函数
  * */
  let findSiblings = function(tag){
    let parent = tag.parentNode;
    let childs = parent.children;
    let sb = [];
    for(let i=0 ; i <= childs.length-1 ; i++){
      if( childs[i]!==tag){
        sb[sb.length] = childs[i];
      }
    }
    return sb ;
  };

  /*
  * 去掉所有兄弟的类
  * */
  let removeSiblingClass =function(tag){
    let sb = findSiblings(tag);
    for(let i=0;i <= sb.length-1;i++){
      sb[i].className = "";
    }
  };

  let initYear = function(){
    let date = new Date();
    let span = document.createElement("span");
    span.innerHTML = date.getUTCFullYear();
    span.className = "on";
    nianBox.appendChild(span);
  };
  /*
  * 初始化月份函数
  * */
  let initMonth = function(){
    for(let i=1;i<=12; i++){
      let span = document.createElement("span");
      span.innerHTML = i+"月";
      yueBox.appendChild(span);
    }
  };

  // 初始化日期
  let initDate = function(){
    for(let i=1; i<=31; i++){
      let span = document.createElement("span");
      span.innerHTML = i+"日";
      riqiBox.appendChild(span);
    }
  };

  // 初始化小时,分钟,秒
  let initHour = function(){
    for(let i=0; i<=23; i++){
      let h = i ;
      let span = document.createElement("span");
      if( h<10){
        h="0"+h;
      }
      span.innerHTML = h +"点";
      hourbox.appendChild( span );
    }
  };
  let initMinute = function(){
    for(let i=0; i<=59; i++){
      let  f = i ;
      let span = document.createElement("span");
      if( f<10){
        f="0"+f;
      }
      span.innerHTML = f +"分";
      minutebox.appendChild( span );
    }
  };
  let initSecond = function(){
    for(let i=0; i<=59; i++){
      let  miao = i ;
      let span = document.createElement("span");
      if( miao<10){
        miao="0"+miao;
      }
      span.innerHTML = miao +"秒";
      secondbox.appendChild( span );
    }
  };

  // 时间文字样式切换函数
  let changeTime = function(tag){
    tag.className = "on";
    removeSiblingClass(tag);
  };

  /*
  * 初始化日历函数
  * */
  let initRili = function(){
    initYear();
    initMonth(); // 初始化月份
    initDate(); // 初始化日期
    initHour(); // 小时
    initMinute();
    initSecond();
  };

  /*
  * 展示当前时间
  * 参数:mydate 时间对象
  * */
  let  showNow = function(mydate){
    let yue = mydate.getMonth();
    let riqi = mydate.getDate();
    let hour = mydate.getHours();
    let minute = mydate.getMinutes();
    let second = mydate.getSeconds();
    // 时间文字样式切换函数
    changeTime(yueBox.children[yue]);
    changeTime(riqiBox.children[riqi-1]);
    changeTime(hourbox.children[hour]);
    changeTime(minutebox.children[minute]);
    changeTime(secondbox.children[second]);
  };

  // 展示时间圆圈函数
  // tag:目标
  // num:数字数量
  // dis:圆圈半径
  let textRound = function(tag,num,dis){
    let span = tag.children ;
    for(let i=0 ; i<=span.length-1; i++){
      span[i].style.transform="rotate("+ (360/span.length)*i+"deg)  translateX("+dis+"px)" ;
    }
  };
  /*
  * 旋转指定“圆圈”指定度数
  * */
  let rotateTag = function(tag , deg){
    tag.style.transform = "rotate("+deg+"deg)";
  };

  let main = function(){
    initRili(); // 初始化日历

    setInterval(function(){
      let mydate = new Date();
      showNow(mydate); // 展示当前时间
    },1000);
    //  n秒后,摆出圆形
    // setTimeout(function(){
      wrapper.className = "wrapper";
      textRound(nianBox,4,0);
      textRound(yueBox,12,70);
      textRound(riqiBox,31,140);
      textRound(hourbox,24,210);
      textRound(minutebox,60,280);
      textRound(secondbox,60,350);
      setInterval(function(){
        let mydate = new Date();
        rotateTag( yueBox , -30*mydate.getMonth());
        rotateTag( riqiBox , -360/31*(mydate.getDate()-1));
        rotateTag( hourbox , -360/24*mydate.getHours());
        rotateTag( minutebox , -6*mydate.getMinutes());
        rotateTag( secondbox , -6*mydate.getSeconds());
      },1000)
    // },1000)
  };
  main();
</script>
</body>
</html>

到了这里,关于存css实现动态时钟背景的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • HTML5 Canvas与JavaScript携手绘制动态星空背景

    目录 一、程序代码 二、代码原理 三、运行效果 这段代码通过 HTML5 的 canvas 元素和 JavaScript 实现了一个星空背景效果。首先,它在页面加载时创建了一个全屏大小的画布,并使用 JavaScript 生成了多个具有不同运动轨道的星星对象。每颗星星都具有随机的半径、位置、运动速度

    2024年02月20日
    浏览(50)
  • 编程笔记 html5&css&js 036 CSS概述

    CSS (Cascading Style Sheets,层叠样式表),是一种用来为结构化文档(如 HTML 文档或 XML 应用)添加样式(字体、间距和颜色等)的计算机语言,CSS 文件扩展名为 .css。通过使用 CSS 我们可以大大提升网页开发的工作效率!在我们的 CSS 教程中,您会学到如何使用 CSS 同时控制多重

    2024年01月22日
    浏览(53)
  • 编程笔记 html5&css&js 044 CSS显示

    CSS 布局 - display 属性。display 属性是用于控制布局的最重要的 CSS 属性。 display 属性规定是否/如何显示元素。每个 HTML 元素都有一个默认的 display 值,具体取决于它的元素类型。大多数元素的默认 display 值为 block 或 inline。 块级元素总是从新行开始,并占据可用的全部宽度(

    2024年01月19日
    浏览(63)
  • 编程笔记 html5&css&js 035 HTML 地理定位

    地理定位有很多事情有关,购物时要知道你在哪吧,驾车时就更是了,所有浏览器还提供了定位的功能,可以在网页中使用。 HTML5 Geolocation(地理定位)用于定位用户的位置。 HTML5 Geolocation API 用于获得用户的地理位置。 鉴于该特性可能侵犯用户的隐私,除非用户同意,否则

    2024年02月02日
    浏览(48)
  • 编程笔记 html5&css&js 034 HTML MathML

    网页上什么都可以出现呀,数学公式是不是也需要显示出来呀?这东西就叫MathML。 HTML5 可以在文档中使用 MathML 元素,对应的标签是 math.../math 。 MathML 是数学标记语言,是一种基于XML(标准通用标记语言的子集)的标准,用来在互联网上书写数学符号和公式的置标语言。 据

    2024年01月21日
    浏览(52)
  • 编程笔记 html5&css&js 032 HTML Canvas

    Canvas画布,就是可以用来画画的地方,不是用户在浏览器上画图,而是会javascript画图。这区别于直接载入一张图片,是可以根据需要进行绘制。 HTML canvas 元素用于通过脚本(通常是 JavaScript)动态地绘制图形。 canvas 元素只是图形的容器。您必须使用脚本来绘制实际的图形。

    2024年01月23日
    浏览(68)
  • 编程笔记 html5&css&js 040 CSS盒子模型

    网页是靠分成不同的块,再赋予这些块各不相同的属性来布局的。所以这个“块”是一个基础。先看块本身的构造。 CSS 盒子模型(Box Model)。所有HTML元素可以看作盒子,在CSS中,\\\"box model\\\"这一术语是用来设计和布局时使用。CSS盒模型本质上是一个盒子,封装周围的HTML元素,它

    2024年01月17日
    浏览(59)
  • 编程笔记 html5&css&js 036 CSS应用方式

    如何在网页中使用CSS?实际上有三种方式。 有三种插入样式表的方法: 外部 CSS 内部 CSS 行内 CSS 通过使用外部样式表,您只需修改一个文件即可改变整个网站的外观! 每张 HTML 页面必须在 head 部分的 link 元素内包含对外部样式表文件的引用。 外部样式在 HTML 页面 head 部分内

    2024年01月22日
    浏览(56)
  • 编程笔记 html5&css&js 041 CSS边框属性

    盒子是由四周的边框组成,边框的属性就构成了盒子的大部分样式。 CSS border 属性允许您指定元素边框的样式、宽度和颜色。 border-style 属性指定要显示的边框类型。 允许以下值: border-style 属性可以设置一到四个值(用于上边框、右边框、下边框和左边框)。 注意:除非设

    2024年01月19日
    浏览(45)
  • 编程笔记 html5&css&js 053 CSS伪元素

    CSS 伪元素用于设置元素指定部分的样式。 什么是伪元素? 设置元素的首字母、首行的样式 在元素的内容之前或之后插入内容 语法 伪元素的语法: ::first-line 伪元素用于向文本的首行添加特殊样式。 下面的例子为所有 p 元素中的首行添加样式: ::first-line 伪元素只能应用于

    2024年01月23日
    浏览(76)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包