文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么使用JS实现电子时钟

2023-07-02 10:44

关注

本篇内容介绍了“怎么使用JS实现电子时钟”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

代码呈上:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title>    <style>        h2{            text-align: center;        }    </style></head><body>    <h2></h2></body><script>    var h2 = document.getElementsByTagName("h2")[0]      function setH1(){        //获取时间戳        var date = new Date();        var year = date.getFullYear();        var month = date.getMonth()+1;        var riqi = date.getDate();        var hour = date.getHours();        var minute = date.getMinutes();        var second = date.getSeconds();        //拼接成指定格式        // var str = year + "/" + month + "/" + riqi + "/" + " " + hour + ":" + minute + ":" + second         var str = `${year}/${month}/${riqi} ${hour}:${minute}:${second}`        //通过innerHTML对标签的内容进行获取或修改        h2.innerHTML= str;    }    //函数的执行    setH1();    var timer = setInterval(function(){        setH1();    },1000)//每间隔1000毫秒(即1秒钟),执行一次函数function</script></html>

讲解要点:

getElementsByTagName返回的是类数组的集合

所以要用[0]来读取元素的值。

var h2 = document.getElementsByTagName("h2")[0]

date.getMonth()得到的是一个介于0到11之间的整数。

所以要执行 +1 操作才能显示正确的月份。

var month = date.getMonth()+1;

效果展示:

怎么使用JS实现电子时钟

 js不仅可以实现电子时钟,也可以实现带有表盘的时钟。

代码呈上:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title>    <style>        *{            margin: 0;padding: 0;        }        .clock{            width: 200px;            height: 200px;            border: 10px solid lightskyblue;            border-radius: 50%;            margin: 0 auto;            box-shadow: 5px 5px 5px lightgray;            background-color: #fff;            position: relative;        }        .clock p{            width: 200px;            height: 20px;                        line-height: 20px;            position: absolute;            top: 90px;        }        .clock p span{            display: block;             width: 20px;            height: 20px;            line-height: 20px;            text-align: center;                    }        #hour {            position: absolute;            transform-origin: center bottom;            width: 6px;            height: 50px;            background-color: tomato;            left: 97px;            top: 50px;        }        #minute {            position: absolute;            transform-origin: center bottom;            width: 4px;            height: 70px;            background-color: deepskyblue;            left: 98px;            top: 30px;        }        #second {            position: absolute;            transform-origin: center bottom;            width: 2px;            height: 90px;            background-color: hotpink;            left: 99px;            top: 10px;        }    </style></head><body>    <div class="clock">        <p><span>1</span></p>        <p><span>2</span></p>        <p><span>3</span></p>        <p><span>4</span></p>        <p><span>5</span></p>        <p><span>6</span></p>        <p><span>7</span></p>        <p><span>8</span></p>        <p><span>9</span></p>        <p><span>10</span></p>        <p><span>11</span></p>        <p><span>12</span></p>        <div id="hour"></div>        <div id="minute"></div>        <div id="second"></div>    </div></body><script>    //获取数字    var ps = document.getElementsByTagName("p");    //获取三个表针    var dHour = document.getElementById("hour");    var dMinute = document.getElementById("minute");    var dSecond = document.getElementById("second");    //设置定时器    var timer = null;    //设置数字的位置    function setNums(){        for (var i=0;i<ps.length; i++){            ps[i].style.transform = `rotate(${120 + i*30}deg)`;            //获取p下边的span标签}            var span = ps[i].getElementsByTagName("span")[0];             span.style.transform = `rotate(${((120 + i*30)*-1)}deg`;        }    }    setNums();    //开启定时器    // timer = setInterval(function(){},1000)   每1000毫秒执行一次function()    timer = setInterval(function(){        changeZhen();    },1000)     //获取时间戳    function changeZhen(){        var date = new Date();        var s = date.getSeconds();        var m = date.getMinutes() + s/60;        var h = date.getHours() + m/60;         dSecond.style.transform = `rotate(${s * 6}deg)`;        dMinute.style.transform = `rotate(${m * 6}deg)`;        dHour.style.transform = `rotate(${h * 30}deg)`;    }</script></html>

讲解要点:

实现思路

表盘:首先用border-radius构造一个圆框,接着用12个p标签承载12个span标签并旋转p标签,由于旋转后,数字方向不正确,所以将span标签的类型改为块标签后,通过旋转改正各数字的方向。

表针:用三个矩形分别代表时针、分针和秒针,通过js函数实现他们在规定时间内旋转的角度。

行标签不支持旋转

所以要将span标签改为块标签后再使用旋转。

.clock p span{            display: block;             width: 20px;            height: 20px;            line-height: 20px;            text-align: center;                    }

表盘的指针除整点外都不是正好指向时间点的。

所以要对分针和时针进行这样的操作:

var m = date.getMinutes() + s/60;var h = date.getHours() + m/60;

注意更改时针、分针和秒针的旋转点

transform-origin: center bottom;

效果展示:

怎么使用JS实现电子时钟

“怎么使用JS实现电子时钟”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯