用JS实现一个实时小闹钟,大家快进来看看吧!

简介: 用JS实现一个实时小闹钟,大家快进来看看吧!

前言

今天我们来聊聊如何使用JS来创建一个实时的小闹钟,这个小闹钟十分的有趣,小伙伴们可以运行一下,看看跟你电脑上的时间是否对的上呢?

我们先来看一下实现的效果

image.png

结构设计

我们先来观察一下这个小闹钟

image.png

我们先将它整体命名为clock,这个闹钟可以分为两个部分,一个外表盘,一个内表盘,我们将它们命名为outer-clock-faceinner-clock-face

接下来我们先来观察外表盘,发现有刻度,我们用marking marking-onemarking marking-twomarking marking-threemarking marking-four四个容器将它们表示出来。

接下来我们来看内表盘,发现里面有时针、秒针、分针这三根针,我们用<div class="hand hour-hand"><div class="hand min-hand">,和<div class="hand second-hand">,来代表它们,最后使用JS使它们呈现动态的效果。

接下来我们来看html部分的代码

html

复制代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <link rel="stylesheet" href="./style.css">
</head>
<body>
  <div class="clock">
    <div class="outer-clock-face">
      <div class="marking marking-one"></div>
      <div class="marking marking-two"></div>
      <div class="marking marking-three"></div>
      <div class="marking marking-four"></div>
      <div class="inner-clock-face">
        <div class="hand hour-hand"></div>
        <div class="hand min-hand"></div>
        <div class="hand second-hand"></div>
      </div>
    </div>
  </div>
  <script src="./index.js"></script>
</body>
</html>

CSS

首先我们附上代码

html {
  background: #CCCCFF;
  font-size: 10px;
}
body {
  height: 100vh;
  margin: 0;
  font-size: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
.clock {
  width: 30rem;
  height: 30rem;
  border: 7px solid #ffebdb;
  border-radius: 50%;
  box-shadow: -4px -4px 10px rgba(67, 67, 67, 0.1),
    inset 4px 4px 10px rgba(168, 145, 128, 0.6),
    inset -4px -4px 10px rgba(201, 175, 155, 0.2),
    4px 4px 10px rgba(168, 145, 128, 0.6);
  background-image: url("https://p26-passport.byteacctimg.com/img/user-avatar/6836faf9f43e8c77ef339218ab8b601b~130x130.awebp");
  background-size: 108%;
  padding: 2rem;
}
.outer-clock-face {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.outer-clock-face::before,
.outer-clock-face::after {
  content: '';
  width: 10px;
  height: 100%;
  background: #596230;
  position: absolute;
  border-radius: 8px;
}
.outer-clock-face::after {
  transform: rotate(90deg);
}
.marking {
  width: 3px;
  height: 100%;
  background: #596230;
  position: absolute;
}
/*通过旋转实现背景图上六根分隔线将时钟分隔的效果*/
.marking-one {
  transform: rotateZ(30deg);
}
.marking-two {
  transform: rotateZ(60deg);
}
.marking-three {
  transform: rotateZ(120deg);
}
.marking-four {
  transform: rotateZ(150deg);
}
.inner-clock-face {
  position: absolute;
  top: 10%;
  left: 10%;
  width: 80%;
  height: 80%;
  background-color: #fffebd;
  z-index: 2;
  border-radius: 50%;
  /*导入外部图片,也就是时钟的背景图*/
  background-image: url("https://p26-passport.byteacctimg.com/img/user-avatar/6836faf9f43e8c77ef339218ab8b601b~130x130.awebp");
  background-size: 108%;
}
.inner-clock-face::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #4d4b63;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.hand {
  width: 50%;
  height: 6px;
  background: red;
  border-radius: 6px;
  position: absolute;
  top: 50%;
  right: 50%;
  margin-top: -3px;
  /*transform-origin修改旋转中心*/
  transform-origin: 100% 50%;
  transform: rotate(90deg);
}
.hour-hand {
  width: 30%;
}
.min-hand {
  width: 40%;
  height: 3px;
}
.second-hand {
  background: #b3b3b3;
  width: 45%;
  height: 2px;
}
  1. 全局样式(html和body) :
  • html选择器用于设置整个HTML文档的全局样式。
  • background属性设置了背景颜色为浅紫色。
  • font-size属性设置了字体大小为10px。
  1. Body样式:
  • body选择器用于设置整个网页的主体样式。
  • height属性设置页面高度为视口高度(100vh)。
  • margin属性设置边距为0,以确保没有默认边距。
  • font-size属性设置字体大小为2rem,相对于根元素的字体大小。
  • display: flexjustify-content以及align-items属性用于将页面内容垂直和水平居中显示。
  1. 时钟容器样式 (.clock) :
  • widthheight属性设置了时钟的宽度和高度,使其呈现为一个圆形。
  • border属性定义了时钟的边框样式。
  • border-radius属性设置边框为圆形。
  • box-shadow属性添加了阴影效果。
  • background-image属性设置了时钟的背景图像。
  • background-size属性控制了背景图像的大小。
  • padding属性为时钟周围添加了内边距。
  1. 外部表盘样式 (.outer-clock-face) :
  • widthheightborder-radius属性定义了外部表盘的样式。
  • ::before::after伪元素用于创建两个垂直的短条形元素。
  • transform属性用于旋转::after伪元素,实现垂直排列。
  1. 刻度样式 (.marking, .marking-one, .marking-two, .marking-three, .marking-four) :
  • 这些类定义了表盘上的标记或刻度的样式。
  • 通过transform属性的旋转来将标记放置在不同的位置,实现分隔线的效果。
  1. 内部表盘样式 (.inner-clock-face) :
  • widthheightborder-radius属性设置内部表盘的样式。
  • background-image属性设置内部表盘的背景图像。
  1. 内部表盘中心点样式 (.inner-clock-face::after) :
  • 伪元素::after用于创建时钟内部的中心点。
  • 它通过widthheightborder-radius等属性定义了一个小圆形。
  1. 指针样式 (.hand, .hour-hand, .min-hand, .second-hand) :
  • 这些类定义了不同类型的时钟指针的样式。
  • 它们设置了指针的宽度、高度、颜色、圆角、位置以及旋转中心。

JS

const secondHand = document.querySelector('.second-hand')
const minHand = document.querySelector('.min-hand')
const hourHand = document.querySelector('.hour-hand')
// console.log(secondHand);
function setTime() {
  const now = new Date()
  // 获取当前的秒数
  const seconds = now.getSeconds() // 30
  const secondsDegrees = seconds * 6 + 90
  secondHand.style.transform = `rotate(${secondsDegrees}deg)`
  // 获取到分数
  const mins = now.getMinutes() // 40
  const minsDegrees = mins * 6 + 90
  minHand.style.transform = `rotate(${minsDegrees}deg)`
  // 获取到时
  const hour = now.getHours() // 21
  const hourDegrees = hour * 30 + 90 + (mins / 60) * 30
  hourHand.style.transform = `rotate(${hourDegrees}deg)`
}
setTime()
setInterval(setTime, 1000)
  1. const secondHand = document.querySelector('.second-hand')const minHand = document.querySelector('.min-hand')const hourHand = document.querySelector('.hour-hand'):这些代码行通过document.querySelector方法获取了页面中具有特定类名的HTML元素,分别表示秒针、分针和时针的指针元素。这些元素将用于通过改变其style.transform属性来旋转它们以模拟时钟的运行。
  2. function setTime():这是一个用于更新时钟指针位置的JavaScript函数。函数内部执行以下操作:
  • 获取当前的日期和时间:通过new Date()创建一个Date对象,然后使用getSeconds()getMinutes()getHours()方法分别获取当前的秒、分和时。
  • 计算秒针的旋转角度:将秒数乘以6并加上90度,这是因为12点位置对应90度,而每秒钟对应6度。然后将计算得到的角度赋值给secondHandstyle.transform属性,通过rotate(deg)来旋转秒针。
  • 计算分针的旋转角度:类似地,将分钟数乘以6并加上90度,然后将计算得到的角度赋值给minHandstyle.transform属性。
  • 计算时针的旋转角度:将小时数乘以30并加上90度,同时考虑分钟数对时针的微调,然后将计算得到的角度赋值给hourHandstyle.transform属性。
  1. setTime():首次调用setTime函数来初始化时钟的指针位置。
  2. setInterval(setTime, 1000):使用setInterval函数,每隔1秒(1000毫秒)调用一次setTime函数,以不断更新时钟指针的位置,从而实现模拟时钟的运行效果。

这段代码的目的是通过JavaScript实现了一个简单的时钟模拟,每秒钟更新一次时、分和秒针的位置,以显示当前的时间。通过获取当前时间并计算相应的旋转角度,它实现了时钟指针的动态运行效果。

小伙伴们赶快去试试吧~

今天的内容就到这啦,如果你觉得小编写的还不错的话,或者对你有所启发,请给小编一个辛苦的赞吧


相关文章
|
前端开发 JavaScript
构建一个动态时钟
构建一个动态时钟
|
Java Nacos Docker
在集成nacos时,端口9848报错但服务器的这个端口是开放的
在集成nacos时,端口9848报错但服务器的这个端口是开放的【1月更文挑战第14天】【1月更文挑战第67篇】
2067 1
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
1585 0
|
8月前
|
机器学习/深度学习 自然语言处理 监控
23_Transformer架构详解:从原理到PyTorch实现
Transformer架构自2017年Google发表的论文《Attention Is All You Need》中提出以来,彻底改变了深度学习特别是自然语言处理领域的格局。在短短几年内,Transformer已成为几乎所有现代大型语言模型(LLM)的基础架构,包括BERT、GPT系列、T5等革命性模型。与传统的RNN和LSTM相比,Transformer通过自注意力机制实现了并行化训练,极大提高了模型的训练效率和性能。
1923 0
|
机器学习/深度学习 移动开发 自然语言处理
深度学习进阶篇-预训练模型1:预训练分词Subword、ELMo、Transformer模型原理;结构;技巧以及应用详解
深度学习进阶篇-预训练模型1:预训练分词Subword、ELMo、Transformer模型原理;结构;技巧以及应用详解
深度学习进阶篇-预训练模型1:预训练分词Subword、ELMo、Transformer模型原理;结构;技巧以及应用详解
基于透镜傅里叶变换特性的4F相关器系统的Matlab仿真(Matlab代码实现)
基于透镜傅里叶变换特性的4F相关器系统的Matlab仿真(Matlab代码实现)
566 0
|
前端开发
前端使用xlsx模板导出表格
【9月更文挑战第10天】在前端使用 `xlsx` 模板导出表格需完成以下步骤:首先引入 `xlsx` 库,准备数据与模板;接着读取模板文件,选择特定工作表并填充数据;最后将填充后的表格转换为二进制数据,创建 Blob 对象并触发下载。整个过程中可根据需求调整模板格式和数据填充方式。
704 6
|
机器学习/深度学习 算法 数据挖掘
从菜鸟到大师:Scikit-learn库实战教程,模型训练、评估、选择一网打尽!
【9月更文挑战第13天】在数据科学与机器学习领域,Scikit-learn是不可或缺的工具。本文通过问答形式,指导初学者从零开始使用Scikit-learn进行模型训练、评估与选择。首先介绍了如何安装库、预处理数据并训练模型;接着展示了如何利用多种评估指标确保模型性能;最后通过GridSearchCV演示了系统化的参数调优方法。通过这些实战技巧,帮助读者逐步成长为熟练的数据科学家。
637 3
|
存储 缓存 前端开发
全面解析:前端超大文件下载的关键技巧与优化策略
全面解析:前端超大文件下载的关键技巧与优化策略
1123 1
全面解析:前端超大文件下载的关键技巧与优化策略