让时钟转起来
创作时间:
作者:
@小白创作中心
让时钟转起来
引用
CSDN
1.
https://blog.csdn.net/lowkeyyh/article/details/145271636
在JavaScript中,对于时间的处理,往往需要借助于
Date对象操作来完成。但是,仅仅使用它来获取时间是无法满足日常业务需求的。例如,有时候我们需要将时间从枯燥的数字转化为更能吸引用户眼球的动态时钟。我们该如何实现呢?
在本节挑战中,我们就遇到了类似情况:
上图中的动态时钟效果,是通过HTML和CSS结合JS中的Date对象来实现的。
本节挑战的代码中,还未实现秒针转动的效果。希望你能观察代码的特点,让秒针转起来。
测试效果
可以通过如下步骤测试效果:
- 右键
01/index.html,选择Open with Live Server。 - 点击右侧的Web服务。
具体操作参考下图:
上述操作会在浏览器中打开新的标签页,如下图所示,请点击01文件夹:
之后,你将看到如下效果:
请根据下述挑战要求,通过修改01/index.js文件,达到让秒针转动起来的效果。
挑战需求
- 秒针的旋转方向应为顺时针。
- 秒针每次旋转的角度为
6deg,且需与当前时间对应。 - 切勿改动源代码中已写好的部分。
要求规定
- 请严格按照考试步骤操作,切勿修改考试默认提供项目中的文件名称、文件夹路径等。
- 满足题目需求后,保持Web服务处于可以正常访问状态,点击「提交检测」系统会自动判分。
- 不要篡改已提供的基础项目中的
id和class等属性值及DOM结构,以免造成检测失败。
通关代码
const oHoure = document.createElement('div');
const oMinute = document.createElement('div');
const oSecond = document.createElement('div');
oHoure.setAttribute('id', 'houre');
oMinute.setAttribute('id','minute');
oSecond.setAttribute('id','second');
oHoure.classList.add('pointer');
oMinute.classList.add('pointer');
oSecond.classList.add('pointer');
const container = document.querySelector('.container');
container.append(oHoure);
container.append(oMinute);
container.append(oSecond);
const nowTime = new Date();
const nowHoure = nowTime.getHours();
const nowMinute = nowTime.getMinutes();
const nowSecond = nowTime.getSeconds();
const houreDeg = (nowMinute / 60) * 30;
const minuteDeg = (nowSecond / 60) * 6;
const secondDeg = nowSecond * 6;
oHoure.style.transform = `rotate(${nowHoure * 30 + houreDeg}deg)`;
oMinute.style.transform = `rotate(${nowMinute * 6 + minuteDeg}deg)`;
oSecond.style.transform = `rotate(${secondDeg}deg)`;
代码解析
HTML 部分
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="https://labfile.oss.aliyuncs.com/courses/9203/style01.css">
<div><span>9</span></div>
<div><span>10</span></div>
<div><span>11</span></div>
<div><span>12</span></div>
<div><span>1</span></div>
<div><span>2</span></div>
<div><span>3</span></div>
<div><span>4</span></div>
<div><span>5</span></div>
<div><span>6</span></div>
<div><span>7</span></div>
<div><span>8</span></div>
const oNumber=document.getElementById("number");
const oDiv=oNumber.getElementsByTagName("div");
const oSpan=oNumber.getElementsByTagName("span");
for(let i=0;i<oDiv.length;i++){
oDiv[i].style.WebkitTransform="rotate(" + i * 30 + "deg)";
for(let j=0;j<oSpan.length;j++){
oSpan[j].style.WebkitTransform="rotate("+ j * -30 + "deg)";
<script src="index.js" type="module"></script>
详细解释:
<!DOCTYPE html>:声明这是一个HTML5文档。<html lang="en">:定义HTML文档的语言为英语。<head>:包含文档的元数据。<meta charset="UTF-8">:指定文档使用UTF-8字符编码。<meta name="viewport" content="width=device-width, initial-scale=1.0">:设置视口的属性,以适应不同设备的屏幕宽度,并设置初始缩放比例为1.0。<title>让时钟转起来</title>:设置网页的标题。<link rel="stylesheet" href="https://labfile.oss.aliyuncs.com/courses/9203/style01.css">:引入外部样式表,为页面添加样式。
<body>:包含页面的主体内容。<div id="warp">:一个具有id为warp的容器元素,可能用于包裹整个时钟。<div id="clock">:一个具有id为clock的元素,可能是时钟的主要显示区域。<div id="number">:可能是用于显示时钟上的数字的容器。- 包含多个
<div><span>X</span></div>:其中X是从1到12的数字,这些元素可能是时钟的数字标记。
- 包含多个
<div class="container">:一个具有class为container的元素,可能是用于容纳时钟指针的容器。
JavaScript 部分
const oNumber = document.getElementById("number");
const oDiv = oNumber.getElementsByTagName("div");
const oSpan = oNumber.getElementsByTagName("span");
for (let i = 0; i < oDiv.length; i++) {
oDiv[i].style.WebkitTransform = "rotate(" + i * 30 + "deg)";
for (let j = 0; j < oSpan.length; j++) {
oSpan[j].style.WebkitTransform = "rotate(" + j * -30 + "deg)";
const oNumber = document.getElementById("number");:通过id获取到id为number的元素,存储在oNumber变量中。const oDiv = oNumber.getElementsByTagName("div");:获取oNumber元素内的所有div元素,存储在oDiv变量中。const oSpan = oNumber.getElementsByTagName("span");:获取oNumber元素内的所有span元素,存储在oSpan变量中。- 第一个
for循环:将oDiv元素集合中的每个元素按i * 30度旋转,可能是为了将数字元素旋转到时钟的不同位置。 - 第二个
for循环:将oSpan元素集合中的每个元素按j * -30度旋转,可能是为了调整数字的显示方向,使其正确显示在时钟上。
<script src="index.js" type="module"></script>
- 引入外部的
index.js文件,且以模块的形式加载。
const oHoure = document.createElement('div');
const oMinute = document.createElement('div');
const oSecond = document.createElement('div');
oHoure.setAttribute('id', 'houre');
oMinute.setAttribute('id','minute');
oSecond.setAttribute('id','second');
oHoure.classList.add('pointer');
oMinute.classList.add('pointer');
oSecond.classList.add('pointer');
const container = document.querySelector('.container');
container.append(oHoure);
container.append(oMinute);
container.append(oSecond);
- 创建三个
div元素分别代表时针(oHoure)、分针(oMinute)、秒针(oSecond),并设置它们的id。 - 为这三个元素添加
pointer类,可能是为了后续通过CSS对它们进行样式控制。 - 通过
document.querySelector('.container')找到class为container的元素,如果找到则将三个指针元素添加到该容器中。
const nowTime = new Date();
const nowHoure = nowTime.getHours();
const nowMinute = nowTime.getMinutes();
const nowSecond = nowTime.getSeconds();
const houreDeg = (nowMinute / 60) * 30;
const minuteDeg = (nowSecond / 60) * 6;
const secondDeg = nowSecond * 6;
oHoure.style.transform = `rotate(${nowHoure * 30 + houreDeg}deg)`;
oMinute.style.transform = `rotate(${nowMinute * 6 + minuteDeg}deg)`;
oSecond.style.transform = `rotate(${secondDeg}deg)`;
function main():定义一个main函数。const nowTime = new Date();:创建一个新的Date对象,获取当前时间。const nowHoure = nowTime.getHours();:获取当前的小时数。const nowMinute = nowTime.getMinutes();:获取当前的分钟数。const nowSecond = nowTime.getSeconds();:获取当前的秒数。const houreDeg = (nowMinute / 60) * 30;:计算时针的旋转角度,根据分钟数计算时针的偏移角度。const minuteDeg = (nowSecond / 60) * 6;:计算分针的旋转角度,根据秒数计算分针的偏移角度。const secondDeg = nowSecond * 6;:计算秒针的旋转角度,秒针每秒旋转6度。oHoure.style.transform =rotate (${nowHoure * 30 + houreDeg} deg)``:将时针旋转到相应的角度。oMinute.style.transform =rotate (${nowMinute * 6 + minuteDeg} deg)``:将分针旋转到相应的角度。oSecond.style.transform =rotate (${secondDeg} deg)``:将秒针旋转到相应的角度。
main();:调用main函数,初始化时钟指针的位置。setInterval(() => { main(); }, 1000);:每1000毫秒(即1秒)调用一次main函数,更新时钟指针的位置,实现时钟转动的效果。
工作流程
- 在HTML中,构建了一个时钟的基本结构,包括数字和一个用于放置指针的容器。
- 在JavaScript中,首先对时钟的数字进行旋转布局,将它们放置在正确的位置。
- 创建时针、分针和秒针元素,并添加到
container元素中。 - 定义
main函数,根据当前时间计算时针、分针和秒针的旋转角度,并设置它们的transform属性进行旋转。 - 调用
main函数初始化时钟指针的位置。 - 使用
setInterval每1秒调用一次main函数,根据当前时间更新时钟指针的旋转角度,从而让时钟不断转动。
热门推荐
我们班的奋斗史:从南大数学系77级毕业之后(上)
李敏镐重启亚洲巡演,周柯宇庆祝出道五周年
王源粉丝见面会:一场走心的感恩盛宴,从策划到互动的全程揭秘
处理家庭矛盾的八个方法
基于隐私保护的分布式数字身份认证技术研究及实践探索
低脂低盐的健康之选:燕麦菠菜三文鱼
饮食调整助力预防脑动脉狭窄
柏林必尝:一根咖喱香肠里的城市味道
柏林探店:从米其林到网红咖喱香肠
2025年成人高考报考条件全解析:年龄、学历要求详解
成人高考报考条件大揭秘:学历提升不再难
王力宏肖战澳门同台,一个举动温暖全网
从网盘宣发到社交媒体:内娱星粉互动方式全面升级
杨幂一个头像变更,折射娱乐产业互动新模式
315来了,教你用甲苯鉴别保障食品安全
冬季高效燃脂,HIIT训练让你瘦不停!
绿瘦教你克服心理障碍,成功减重
中国居民健康体重管理之减重行动20条:权威指导下的科学减重指南
苯酚:医药界的“万金油”
约瑟夫·李斯特:用苯酚开启现代外科革命
家用监控摄像头如何防黑客入侵?这些安全防护措施请收好
冬季熟鸡蛋安全食用:加热储存方法与注意事项
熟鸡蛋二次加热有讲究:24小时、100℃是关键
熟鸡蛋二次加热安全指南:不会致癌,注意保存方法
隔夜熟鸡蛋食用指南:保存得当是关键
熟鸡蛋怎么加热才安全?两种方法教你正确食用
血脂检查:护心秘籍大揭秘
瑞金医院推出智慧化验单:让数据“说话”,让医疗更有温度
高脂肪食物对血脂检查的影响有多大?
唐山烧烤店打人案:陈志伟的法律责任解析