使用js简单实现新年倒计时

您所在的位置:网站首页 今年过年倒计时还有多少天 使用js简单实现新年倒计时

使用js简单实现新年倒计时

2023-07-25 07:58| 来源: 网络整理| 查看: 265

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第10天,点击查看活动详情

前言

2022年已经接近尾声了,马上又是新的一年。每天都数着日子,期待放假,回家过年了。今天来简单实现一个倒计时功能,能够实时看到还有多少天就过年了。

具体实现 1. 画红灯笼

为了增加一些快过年的喜庆氛围,因此使用css实现了两个红灯笼展示到页面上。 灯笼分成4个部分组成,灯笼顶部、灯笼主体、灯笼底部、灯笼穗。

福 ... 复制代码

灯笼的顶部、底部为黄色长方形的形状,并设置不同方向边角的弧度,实现形状圆滑

.lantern-top, .lantern-bottom { margin: 0 auto; position: relative; width: 25%; height: 7%; background-color: #ffd700; z-index: 11; } .lantern-top { border-top-left-radius: 10px; border-top-right-radius: 10px; } 复制代码

灯笼主体为宽高一致的正方形,并使用border-radius属性设置边角的弧度,实现灯体圆滚滚的形状。使用box-shadow属性设置阴影,实现灯笼发光的效果

.lantern-inner { width: 50%; height: 50%; margin: 0 auto; position: relative; font-size: 60px; color: #ffd700; border-radius: 40px; box-shadow: 0px 0px 206px 34px rgba(250, 108, 0, 1); background-color: #f00; display: flex; justify-content: center; align-items: center; z-index: 20; } 复制代码

灯穗由10个红色、黄色相间的长条组成,给偶数的li设置黄色的背景,奇数的li设置红色的背景,并设置一个左右晃动的动画。整个灯笼也需要加上这个动画,实现在风中摇曳的效果。

@keyframes wobble { 0%, 100% { transform: rotate(3deg); } 50% { transform: rotate(-3deg); } } 复制代码 2. 实现新年倒计时效果

a. 首先获取页面中展示倒计时天数、小时数、分钟数、秒数的各个元素。

b. 计算剩余时间

获取2023年除夕(1月21号)的时间戳、以及当前日期的时间戳,两个时间戳相减,得到剩余的时间,根据这个时间计算有多少天、多少小时、多少分钟、多少秒,再把计算出的相应数值展示到页面上。(ps: 当剩余时间为0或者小于0,则不用展示时间了,直接展示文字‘新年快乐’)

c. 写一个定时器,每个一秒钟,执行一次计算时间的函数,实现时间的实时改变。当剩余时间小于等于1秒钟,则可以清除定时器,不用计算剩余时间了

const countText = document.querySelector('.count-down') const d = document.querySelector('.days'); const h = document.querySelector('.hours'); const m = document.querySelector('.minutes'); const s = document.querySelector('.seconds'); function getTrueNumber(num) { return num < 10 ? "0" + num : num; } function calculateRemainingTime() { const comingYear = new Date().getFullYear() + 1; const comingDate = new Date(`Jan 21, ${comingYear} 00:00:00`); const now = new Date(); const remainingTime = comingDate.getTime() - now.getTime(); const days = Math.floor(remainingTime / (1000 * 60 * 60 * 24)); const hours = Math.floor((remainingTime % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); const mins = Math.floor((remainingTime % (1000 * 60 * 60)) / (1000 * 60)); const secs = Math.floor((remainingTime % (1000 * 60)) / 1000); d.innerHTML = getTrueNumber(days); h.innerHTML = getTrueNumber(hours); m.innerHTML = getTrueNumber(mins); s.innerHTML = getTrueNumber(secs); if(remainingTime { const remainingTimeInMs = calculateRemainingTime(); if (remainingTimeInMs


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3