【HTML】再见2022!一起来写一个响应式跨年倒计时吧!(附源码)
创始人
2024-05-02 20:53:40
0

在这里插入图片描述

💂作者简介: THUNDER王,一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学会计学专业大二本科在读,同时任汉硕云(广东)科技有限公司ABAP开发顾问。在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较深入的研究。


💅文章概要: 各位C站的小伙伴们,马上就要迎来我们一年一度的元旦和春节啦,值此之际,让我们一起来写一个响应式跨年倒计时吧!无论是电脑,手机还是平板都可以完美适配哦!


🤟每日一言: 保护好你的梦想,等到它开花结果的那天,它会让你俯视所有曾经看低你的人。


目录

    • 前言
    • 响应式布局介绍
    • 响应式跨年倒计时效果演示
      •  PC端效果演示
      •  手机端效果演示
      •  IPAD竖屏效果演示
      •  IPAD横屏效果演示
    • 实现思路
      •  背景的设置
        •   HTML+CSS源码
      •  上浮泡泡效果实现
        •   HTML源码
        •   CSS源码
      •  倒计时代码原理实现
        •   JAVASCRIPT源码
      •  响应式布局设计
        •   CSS源码
    • 完整源码
    • 写在最后的话


前言

在这里插入图片描述

  各位C站的小伙伴们,马上就要迎来我们一年一度的元旦和春节啦,值此之际,让我们一起来写一个响应式跨年倒计时吧!无论是电脑,手机还是平板都可以完美适配哦!


响应式布局介绍

   响应式布局 Ethan Marcotte 2010年5月份 提出的一个概念,简而言之,就是 一个网站能够兼容多个终端 ——而不是为每个终端做一个特定的版本。这个概念是为解决移动互联网浏览而诞生的。
   响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验 ,而且随着大屏幕移动设备的普及,用“大势所趋”来形容也不为过。随着越来越多的设计师采用这个技术,我们不仅看到很多的创新,还看到了一些成形的模式。

在这里插入图片描述


响应式跨年倒计时效果演示

  下面展示四种情况下的效果演示,包括 PC端手机端IPAD竖屏IPAD横屏

 PC端效果演示

在这里插入图片描述

 手机端效果演示

在这里插入图片描述

 IPAD竖屏效果演示

在这里插入图片描述

 IPAD横屏效果演示

在这里插入图片描述


实现思路

  看完效果图后,各位小伙伴们肯定很想知道实现的思路,接下来我将分步骤逐一进行讲解,如果想要获取源码的小伙伴可以跳过该部分,直接前往最后的完整源码章节!,在分布讲解种我会将HTMLCSSJAVASCRIPT三个部分全部放在同一个文件中,方便各位小伙伴们获取!
  我将实现思路分成了如下四个部分,列举如下:

  • 背景的设置
  • 上浮泡泡效果实现
  • 倒计时代码原理实现
  • 响应式布局设计

 背景的设置

  通过使用HTML和CSS可以完成整个倒计时的背景设计,背景颜色采取了渐变色的设计,更具美感搭配上浮泡泡有一种置身绿色海洋的身临其境!
在这里插入图片描述

  HTML+CSS源码


New Year Count Down

Countdown to new year
NA

NA
NA
NA
NA

 上浮泡泡效果实现

在这里插入图片描述

  采取HTML+CSS样式设计可以设计出泡泡的样式,最后在CSS中使用@keyframes rise 可以实现泡泡的上浮

  HTML源码

  复制如下源码粘贴到标签的下方
在这里插入图片描述

  CSS源码

  复制如下源码粘贴到标签之间

.bubble-container{position: absolute;width: 100%;height: 100%;z-index: 0;overflow: hidden;top:0;left:0;
}.bubble-container .bubble{position: absolute;bottom: -10rem;width:  4rem;height: 4rem;background-color: #f1f1f1;border-radius: 50%;opacity: .5;animation: rise 10s infinite ease-in;
}.bubble-container .bubble-1 {width: 4rem;height: 4rem;left: 10%;animation: 8s;
}.bubble-container .bubble-2 {width: 2rem;height: 2rem;left: 20%;animation-duration: 5s;animation-delay: 1s;
}.bubble-container .bubble-3 {width: 5rem;height: 5rem;left: 35%;animation-duration: 7s;animation-delay: 2s;
}.bubble-container .bubble-4 {width: 8rem;height: 8rem;left: 50%;animation-duration: 11s;animation-delay: 0s;
}.bubble-container .bubble-5 {width: 3.5rem;height: 3,5rem;left: 55%;animation-duration: 6s;animation-delay: 1s;
}.bubble-container .bubble-6 {width: 4.5rem;height: 4,5rem;left: 65%;animation-duration: 8s;animation-delay: 3s;
}.bubble-container .bubble-7 {width: 9rem;height: 9rem;left: 75%;animation-duration: 12s;animation-delay: 2s;
}.bubble-container .bubble-8{width: 2.5rem;height: 2.5rem;left: 80%;animation-duration: 6s;animation-delay: 2s;
}@keyframes rise {0% {bottom: -10rem;transform: translateX(0); }50% {transform: translate(10rem);}100%{bottom: 1080px;transform: translateX(-20rem);}
}

 倒计时代码原理实现

在这里插入图片描述

  使用JAVASCRIPT嵌入到标签之中,可以实现倒计时的效果,利用了计数器的原理获取下一年的时间和距离2023年剩余的时间

  JAVASCRIPT源码

  复制如下源码粘贴到标签之间

// 自动为下一年function newYear() {var Y = new Date().getFullYear() + 1var newDay = Y + '/1/1 00:00:00'var countDate = new Date(newDay);var now = new Date().getTime()gap = countDate - now;var second = 1000var minute = second * 60var hour = minute * 60var day = hour * 24var d = Math.floor(gap / day)var h = Math.floor((gap % day) / hour)var m = Math.floor((gap % hour) / minute)var s = Math.floor((gap % minute) / second)// 此处可删除d = addZero(d)h = addZero(h)m = addZero(m)s = addZero(s)// func end// 显示的年document.getElementById('Year').innerText = Y// 倒计时document.getElementById('day').innerText = ddocument.getElementById('hour').innerText = hdocument.getElementById('minute').innerText = mdocument.getElementById('second').innerText = s}// 数字小于10前面就加0function addZero(num) {return num < 10 ? '0' + num : num}setInterval(() => {newYear()}, 1000)

 响应式布局设计

在这里插入图片描述

  通过不同的媒介类型条件定义样式表规则媒介查询CSS可以更精确作用于不同的媒介类型和同一媒介的不同条件。媒介查询的大部分媒介特性都接受minmax用于表达”大于或等于””小于或等于”。如:width会有min-widthmax-width媒介查询可以被用在CSS中的@media@import规则上,也可以被用在HTMLXML中。通过这个标签属性,我们可以很方便的在不同的设备下实现丰富的界面,特别是移动设备,将会运用更加的广泛。

  CSS源码

  复制如下源码粘贴到标签之间,便可实现多分辨率下的完美显示!

@media screen and (max-width:1024px){*{margin: 0;padding: 0;}html{background: rgb(0,21,32);}.container{width: 100%;margin: 20% 0;padding: 0%;background: rgb(0,21,32);}.container div{margin: 0;color: #fff;line-height: normal;}.container h2 span{color: #fff;display: block;text-align: center;font-size: 1em;}.container h2:first-child div{font-size: 6em;text-align: center;margin: 10% 0;}.countdouwn{display: flex;justify-content: space-around;margin: 0;}.countdouwn div{width: 20%;height: 13vw;margin: 0 10px;line-height: 13vw;font-size: 2.3em;position: relative;text-align: center;background: #333333;color: #ffffff;font-weight: 500;}.countdouwn div:before{content:'';position: absolute;bottom: -30px;left: 0;width: 100%;height: 30px;background: #aaa;color: #333;font-size: .35em;line-height: 35px;font-weight: 300;}.countdouwn #day:before{content: 'Days';}.countdouwn #hour:before{content: 'Hours';}.countdouwn #minute:before{content: 'Minutes';}.countdouwn #second:before{content: 'Seconds';}
}

完整源码

  各位小伙伴只需要复制以下所有源码然后新建一个html文件将源码复制进去,然后就可以直接运行了!


2023 countdown

Countdown to new year
NA

NA
NA
NA
NA

写在最后的话

  本文花费大量时间介绍了如何创建一个响应式布局的跨年倒计时代码,希望能帮助到各位小伙伴,码文不易,还望各位大佬们多多支持哦,你们的支持是我最大的动力!
在这里插入图片描述

✨原创不易,还希望各位大佬支持一下\textcolor{blue}{原创不易,还希望各位大佬支持一下}原创不易,还希望各位大佬支持一下

👍 点赞,你的认可是我创作的动力!\textcolor{9c81c1}{点赞,你的认可是我创作的动力!}点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!\textcolor{ed7976}{收藏,你的青睐是我努力的方向!}收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!\textcolor{98c091}{评论,你的意见是我进步的财富!}评论,你的意见是我进步的财富!

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...